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

I am having a difficulty running the following Macro codes. 

First of all, I work on 126 datasets, like: 

 

USA_2000, USA_2001 ... USA_2017 

JPN_2000, JPN_2001 ... JPN_2017 

...

Ind_60_2000, Ind_60_2001, ... Ind_60_2017 

 

126 datasets are about 7 regions over 2000~2017. 

 

Now, my codes runs as follows: 

 

%LET var1=USA;
%LET var2=JPN;
%LET var3=GBR;
%LET var4=Ind_73;
%LET var5=Ind_36;
%LET var6=Ind_28;
%LET var7=Ind_60;

%MACRO Onemode_network;
%DO i=1 %TO 1;
%DO j=2000 %TO 2017;
DATA &&var&i.._&j (drop=rc);
set &&var&i.._&j (rename=(source=source1))
&&var&i.._&j (obs=0 rename=(source=target1));
if _n_=1 then do;
declare hash h (dataset:'&&var&i.._&j (rename=(source=target1))',multidata:'y');
h.definekey('target');
h.definedata('target1');
h.definedone(); end;
do rc=h.find() by 0 until (h.find_next()^=0);
if source1<target1 then output;
end;
run;
%END;
%END;
%MEND Onemode_network;

%Onemode_network;

 

When I run them, I keep getting the following errors, 

 

ERROR: Invalid data set name at line 2 column 38. 

 

What am I doing wrong with here? Since my codes are a patchwork from my questions and answers from multiple experts, 

I don't see the internal logic in codes. 

 

Many thanks in advance! 

 

KS -, 

 

 

1 ACCEPTED SOLUTION

Accepted Solutions
Astounding
PROC Star

I'm not sure if this will fix everything, since it's hard to relate to the error message referring to line 2.  But this definitely needs to be fixed.

 

References to macro variables in single quotes do not get resolved.  This line is incorrect:

 

(dataset:'&&var&i.._&j (rename=(source=target1))',multidata:'y');

At a minimum, this needs to switch to double quotes to permit macro references to resolve:

(dataset:"&&var&i.._&j (rename=(source=target1))",multidata:'y');

So start by correcting the known error, and we'll see whether any problems remain.

View solution in original post

6 REPLIES 6
PeterClemmensen
Tourmaline | Level 20

First and foremost.. What is your goal here? There is certainly a better way and we'll find it 🙂

KS99
Obsidian | Level 7

Thank you for your kind interest in my problems! 

 

In the past, I obtained a set of codes from a SAS expert here

concerning how to create all the possible pair combinations (Cartesian product) for observations by each group. 

The context is as follows: 

 

Hi, I need your help! 

Suppose I have the following dataset, 

 

data Network;
input  Cusip  Analyst;
cards;
1  1
1  2  
1  3 
2  8
2  9
2  10
2  11
2  12
3  45
3  46
;
run; 

 

I want to create a new dataset that looks like below, 

__________________________

Cusip Var1 Var2 

1   1    2
1   2    3  
1   3    1
2   8    9
2   9  10
2 10  11
2 11  12 
2 12    8

2   8   11
2   8   10
2   9   12

2   9   11
2  10  12 
3  45  46
________________________ 

 

In other words, I want to create nC2 for each Cusip. 

I tried using Cartesian production (full merging), but cleaning the duplicates again throws me into the mire. 

Many thanks, in advance! Sincerely,  KS -, 

 

 The answer code that I got was the following: 

 

 

data want (drop=rc);
  set network (rename=(analyst=var1)) network (obs=0 rename=(analyst=var2));

  if _n_=1 then do;
    declare hash h (dataset:'network (rename=(analyst=var2))',multidata:'y');
      h.definekey('cusip');
      h.definedata('var2');
      h.definedone();
  end;
  do rc=h.find() by 0 until (h.find_next()^=0);
    if var1<var2 then output;
  end;
run 

 

Now I was going to run this code over multiple datasets. 

Sorry that my first post didn't explain things clearly. 

 

Anyway, the problem is solved by simple replacing single quotation by double quotation marks within Macro. 

 

Many thanks! 

 

Sincerely, 

KS -, 

 

japelin
Rhodochrosite | Level 12

I think you should first specify the

options mprint mlogic;

to find out where the problem is.

 

Also, if all 126 datasets are in the WORK library and there are no other datasets in the WORK library,

the looping process will be easier if you use sashelp.vstable.

data _null_;
  set sashelp.vstable;
  where libname='WORK';
  call symputx(cats('var',_n_),memname);
  call symputx('obs',_n_);
run;

%MACRO Onemode_network;
  %do i=1 %to &nobs;

  DATA &&var&i.._&j (drop=rc);
/* processing... */
  run;

  %end;
%MEND Onemode_network;
KS99
Obsidian | Level 7

Thank you very much for letting me know sashelp.vstable ! 

I will use it for my future work, 

 

Sincerely, 

KS -, 

 

Astounding
PROC Star

I'm not sure if this will fix everything, since it's hard to relate to the error message referring to line 2.  But this definitely needs to be fixed.

 

References to macro variables in single quotes do not get resolved.  This line is incorrect:

 

(dataset:'&&var&i.._&j (rename=(source=target1))',multidata:'y');

At a minimum, this needs to switch to double quotes to permit macro references to resolve:

(dataset:"&&var&i.._&j (rename=(source=target1))",multidata:'y');

So start by correcting the known error, and we'll see whether any problems remain.

KS99
Obsidian | Level 7

Thank you so much, Astounding! 

Simply replacing single with double quotation marks truly helped. 

Now the codes run perfectly. 

 

Have a nice weekend, 

 

Sincerely, 

KS -, 

 

sas-innovate-2024.png

Available on demand!

Missed SAS Innovate Las Vegas? Watch all the action for free! View the keynotes, general sessions and 22 breakouts on demand.

 

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.

Click image to register for webinarClick image to register for webinar

Classroom Training Available!

Select SAS Training centers are offering in-person courses. View upcoming courses for:

View all other training opportunities.

Discussion stats
  • 6 replies
  • 591 views
  • 2 likes
  • 4 in conversation