java的sas数据安全_使用sas中的do循环指定数据信息

这里有一些方法可行 . 最直接可以翻译的方法是使用宏语言 .

你需要将这两个循环翻译成这样的东西:

%do i = 1940 %to 2018;

%do j = 1 %to 12;

informat _&i.M&j. best32.;

%end;

%end;

注意 % 那里 . 这也必须是一个宏观;你不能在普通的datastep代码中这样做 .

我会重写它以使用像这样的宏:

%macro make_ym(startyear=, endyear=, separator=);

%local i j;

%do i = &startyear. %to &endyear.;

%do j = 1 %to 12;

_&i.&separator.&j.

%end;

%end;

%mend make_ym;

data test;

infile 'abc.csv' delimiter = ',' MISSOVER DSD lrecl=32767 firstobs=2 ;

informat Country_Name $34. ;

informat %make_ym(startyear=1940,endyear=2018,separator=M) best32.;

informat Base_Year $1. ;

format %make_ym(startyear=1940,endyear=2018,separator=M) best12.;

format Base_Year $1. ;

input

Country_Name $

%make_ym(startyear=1940,endyear=2018,separator=M)

Base_Year $;

run;

我在输入中的yMm位之后取出 $ ,因为您将它们声明为数字 .

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值