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

Hi,

 

I am trying to convert the characters to hexadecimal. Here you have an example.

 

I have a variable named Model , where model= 3096-712 which is a string.

I need to assign it to a new variaable called V1_hex = '3096'x where it should take the first four characters of model.

Please help me with some solution.

Thank you,

Regards,

Pon1.

 

I tried using this code

DATA MYDATA;
format V1_HA V2_CHA $Char8.;
V1_CHA='3096-712';
V2_CHA='3096-708';
run;
Data Outdata;
format V1_Hex V2_Hex $hex4.;
V1_Hex=put(Substr(V1_CHA,1,4),$hex4.);
V2_Hex=put(SubStr(V2_CHA,1,4),$hex4.);
run;
proc Print Data=outdata;
run
//*

I go the output as

.............................................

The SAS System

Obs V1_Hex  V2_Hex   V1_CHA       V2_CHA

1        F4        F4             .                     .    

 

Help me to code for abtaining the 

1 ACCEPTED SOLUTION

Accepted Solutions
Kurt_Bremser
Super User

Use the input() function:

DATA MYDATA;
format V1_CHA V2_CHA $Char8.;
V1_CHA='3096-712';
V2_CHA='3096-708';
run;

Data Outdata;
set mydata;
format V1_Hex V2_Hex $hex4.;
V1_Hex = input(substr(V1_CHA,1,4),$hex4.);
V2_Hex = input(SubStr(V2_CHA,1,4),$hex4.);
run;

proc print data=outdata noobs;
run;

Result:

V1_CHA      V2_CHA      V1_Hex    V2_Hex

3096-712    3096-708     3096      3096 

View solution in original post

4 REPLIES 4
Kurt_Bremser
Super User

Use the input() function:

DATA MYDATA;
format V1_CHA V2_CHA $Char8.;
V1_CHA='3096-712';
V2_CHA='3096-708';
run;

Data Outdata;
set mydata;
format V1_Hex V2_Hex $hex4.;
V1_Hex = input(substr(V1_CHA,1,4),$hex4.);
V2_Hex = input(SubStr(V2_CHA,1,4),$hex4.);
run;

proc print data=outdata noobs;
run;

Result:

V1_CHA      V2_CHA      V1_Hex    V2_Hex

3096-712    3096-708     3096      3096 
Pon1
Calcite | Level 5

Hi 

 

 

 

 

Kurt_Bremser
Super User

Please run my code as posted. Your code misses the necessary set statement. You can see this in the log, it will complain about uninitialized variables.

Pon1
Calcite | Level 5

Hi 

 

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

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