BookmarkSubscribeRSS Feed
scaldera
Calcite | Level 5

How can I break up a string into new string variables using the uppercase letters in the string as the delimiters?  For example, I have a name variable that looks like:  JohnSmith. I want to transform it into two variables -- first = John, last = Smith.  I tried scan (varname, _n_, ' ', ku) but it only returns the upper case letters not the lower case letters following. Thanks!

3 REPLIES 3
Peter_C
Rhodochrosite | Level 12

although there are sas functions like anylower() and notlower() picking out the case changes sounds more suitable for the prx functions.

good luck

art297
Opal | Level 21

If your names are always like those shown in your example you might be able to use something as simple as:

data have;

  input name $30.;

  cards;

JonathanSmith

MaryMcDougal

;

data want;

  set have;

  first=substr(name,1,anyupper(substr(name,2)));

  last=substr(name,anyupper(substr(name,2))+1);

run;

SAS Innovate 2025: Register Now

Registration is now open for SAS Innovate 2025 , our biggest and most exciting global event of the year! Join us in Orlando, FL, May 6-9.
Sign up by Dec. 31 to get the 2024 rate of just $495.
Register now!

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 3 replies
  • 1071 views
  • 0 likes
  • 4 in conversation