The results of the ANYPUNCT
function depend directly on the translation table that is in effect
(see “TRANTAB= System Option” in the
SAS National Language Support (NLS): Reference Guide) and indirectly on the ENCODING and LOCALE system
options.
The ANYPUNCT function
searches a string for the first occurrence of a punctuation character.
If such a character is found, ANYPUNCT returns the position in the
string of that character. If no such character is found, ANYPUNCT
returns a value of 0.
If you use only one
argument, ANYPUNCT begins the search at the beginning of the string.
If you use two arguments, the absolute value of the second argument,
start,
specifies the position at which to begin the search. The direction
in which to search is determined in the following way:
-
If the value of
start is
positive, the search proceeds to the right.
-
If the value of
start is
negative, the search proceeds to the left.
-
If the value of
start is
less than the negative length of the string, the search begins at
the end of the string.
ANYPUNCT returns a value
of zero when
-
the character that you are searching
for is not found
-
the value of
start is
greater than the length of the string
-
Note: For
z/OS systems, the ANYPUNCT
function by default reports a small list of characters as punctuation.
This restraint of the function is a holdover from older systems that
defined a limited set of printable characters. To use a current definition
of the punctuation characters, specify an appropriate LOCALE option
value (for example,
LOCALE=ENGLISH
).