BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
Jsendzik
Fluorite | Level 6

Hello,

I was recently given some numeric data the ends in a character. The last characce ter corresponds to a numeric variable.

Ex.

000A = 0001

000B = 0002

Right now I'm using the Substr() function to get the last character of every variable, then I replace it and join the new converted number back on. I was wondering if you all knew a more efficient method.

Thanks

1 ACCEPTED SOLUTION

Accepted Solutions
Peter_C
Rhodochrosite | Level 12

Looks like 'zoned decimal' for which SAS has an informat.

View solution in original post

2 REPLIES 2
snoopy369
Barite | Level 11

substr(yourvar,4,1) = put(rank(substr(yourvar,4,1))-64,1.);

assuming it's always uppercase and you are on a standard ASCII system (not EBCDIC).  'A'=65 through 'Z'=90.  Of course if you go past I ('9' in this) you will have a problem of space (what happens to the second digit).

Peter_C
Rhodochrosite | Level 12

Looks like 'zoned decimal' for which SAS has an informat.

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
  • 2 replies
  • 1032 views
  • 4 likes
  • 3 in conversation