BookmarkSubscribeRSS Feed
mcook
Quartz | Level 8

Working with data similar to the following

data table1;
input Location $ Number;
datalines;
Home 5
Store 4
work 10
Gym 3
Schools 7
Moon 8
;
run;

data table2;
input Place $;
datalines;
Home 
Work
School
Moon
;
run;

I am trying to match the Place in Table 2 with the corresponding number from Table1 with a left join.  But as you can see, there is a Pluralization and Capitalization difference between the two tables.  

 

Running this code

proc sql noprint;
create table Joined as 
select place, number 
from Table2 Left Join Table1
on upcase(Table2.Place) = upcase(Table1.Location);
quit;

running this outputs

Table1.PNG

I would like School to be matched with Schools.  Is there a way in a left join to accomplish this?

 

Or disregarding all of that.  Is there an easier way to match the values of Place in Table2 with the numbers from Table1?

5 REPLIES 5
ChrisNZ
Tourmaline | Level 20

> I would like School to be matched with Schools.
What's the match criterion?

mcook
Quartz | Level 8

I'm not sure what you  mean by match criterion.  Basically I would just like pluralization to be ignored.  

ChrisNZ
Tourmaline | Level 20

Another way:

where      upcase(Table2.PLACE)      =      upcase(Table1.LOCATION)
   or cats(upcase(Table2.PLACE),'S') =      upcase(Table1.LOCATION)
   or      upcase(Table2.PLACE)      = cats(upcase(Table1.LOCATION),'S')

Note that while stricter and closer to your requirements than the two solutions already proposed, this logic can still perform erroneous matches, such as BAS and BASS.

 

Ksharp
Super User

You could try some fuzz matched FUNCTION. like spedis() complev() compgen() .........

 

data table1;
input Location $ Number;
datalines;
Home 5
Store 4
work 10
Gym 3
Schools 7
Moon 8
;
run;

data table2;
input Place $;
datalines;
Home 
Work
School
Moon
;
run;
proc sql noprint;
create table Joined as 
select place, number 
from Table2 Left Join Table1
on spedis( upcase(Table2.Place) , upcase(Table1.Location) ) < 10;
quit;
PGStats
Opal | Level 21

You could use the truncated equality operator (eqt, the SQL equivalent to := in the data step) :

 

proc sql;
select place, number 
from Table2 Left Join Table1
on upcase(Table2.Place) eqt upcase(Table1.Location);
quit;

of course, this won't make "foot" equal "feet" 😁

PG

SAS Innovate 2025: Save the Date

 SAS Innovate 2025 is scheduled for May 6-9 in Orlando, FL. Sign up to be first to learn about the agenda and registration!

Save the date!

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