楼主: priss111
9172 20

[问答] 请问各位大侠:如何通过proc export 语句一次性导出20多个数据集?谢谢! [推广有奖]

  • 0关注
  • 5粉丝

已卖:9份资源

副教授

16%

还不是VIP/贵宾

-

威望
0
论坛币
153 个
通用积分
47.5396
学术水平
11 点
热心指数
14 点
信用等级
10 点
经验
14935 点
帖子
472
精华
0
在线时间
808 小时
注册时间
2008-3-30
最后登录
2025-3-17

楼主
priss111 发表于 2011-4-6 10:39:05 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
请问大侠:如何通过proc export 语句一次性导出20多个数据集?谢谢!

1.

data data1 data2 … data22;

set spouse1;

if citycode=4401
then
output data1;

if citycode=4402
then
output data2;

If citycode=4499 then output data22;

run;

2.

proc
export
data=data1

outfile="F:data1.csv"

dbms=csv replace;

run;


proc
export
data=data2

outfile="F:data2.csv"

dbms=csv replace;

run;

proc
export
data=data22

outfile="F:data22.csv"

dbms=csv replace;

run;


请问:如何使用proc export语句将第1步生成的data1-data2222个数据集)一次性导出成22csv数据集?

或者请问:
能否将上述12两步合并成一步一次性导出22csv数据集?
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:export 请问各位大侠 xport 各位大侠 expo 大侠 proc 数据集 语句 export

回帖推荐

edumetric 发表于2楼  查看完整内容

用macro可以提高效率,你试试下面的语句是否可行 %macro exportdata; %do i=1 %to 22; proc export data=data&i outfile="F:\data&i..csv" dbms=csv replace; run; %mend exportdata; %exportdata;

本帖被以下文库推荐

沙发
edumetric 发表于 2011-4-6 11:01:31
用macro可以提高效率,你试试下面的语句是否可行

%macro exportdata;
%do i=1 %to 22;
proc export data=data&i outfile="F:\data&i..csv" dbms=csv replace;
run;
%mend exportdata;
%exportdata;
priss111 发表于 2011-4-6 10:39
请问大侠:如何通过proc export 语句一次性导出20多个数据集?谢谢!

1.

data data1 data2 … data22;



set spouse1;



if citycode=4401
then
output data1;



if citycode=4402
then
output data2;





If citycode=4499 then output data22;


run;


2.



proc
export
data=data1



outfile="F:data1.csv"



dbms=csv replace;


run;



proc
export
data=data2



outfile="F:data2.csv"



dbms=csv replace;


run;


proc
export
data=data22



outfile="F:data22.csv"



dbms=csv replace;


run;


请问:如何使用proc export语句将第1步生成的data1-data2222个数据集)一次性导出成22csv数据集?

或者请问:
能否将上述12两步合并成一步一次性导出22csv数据集?
已有 2 人评分学术水平 热心指数 收起 理由
crackman + 1 鼓励积极发帖讨论
priss111 + 1 + 1 非常感谢!

总评分: 学术水平 + 1  热心指数 + 2   查看全部评分

藤椅
priss111 发表于 2011-4-6 11:14:47
2# edumetric

可以。
%macro exportdata;
%do i=1 %to 22;
proc export data=data&i outfile="F:data&i..xls" dbms=excel replace;
run;
%end;
%mend exportdata;
%exportdata;

导出的csv数据集有个观测错行,所以就改成excel数据集了。




上面的问题解决了,谢谢!
另外又遇到一个问题,
请问:如何一次性将这22excel数据集中的变量(var1-var73)改为中文的变量名?

因为导出的22xls数据集的变量名为var1-var73,想把excel中的var1-var73变量名改为中文的变量名, 这个如何在proc export 格式中设置一下,谢谢!
要不还要手动重防22次将每个数据集中的var1-var73改成中文的变量名(比如,年龄、性别)。

板凳
edumetric 发表于 2011-4-6 11:29:18
我用的SAS版本现实中文是乱码的,我看到的文献里面,有的说可以把SAS的data步的数据的变量用中文命名的,加一个options validvarname=any; 好像就可以用中文命名的。如果这个真的可以的话,你可以在data步就把变量名改为中文。我不确定行不行。因为我很少用中文命名。非要用中文的话,我一般会用R来做。或许别人有更好的方法,不好意思,帮不到你。

报纸
priss111 发表于 2011-4-6 11:34:39
4# edumetric

好,谢谢!!

因为excel要发给不同的人,所以必须写一个变量名说明,
要是直接将英文的var1-var73改为中文就不用另写一个变量名说明了,
要不还得重复弄22次。
有3个母本数据集就得重复66次(手动),比较麻烦。

要是R可以,麻烦您能不能写个R的code,谢谢!

地板
edumetric 发表于 2011-4-6 11:42:03
你的SAS能否正常显示中文,如果可以,你也可以尝试用print label的方法
把你的data里面的变量用label设为中文名字,然后export的时候输出
ods html file="f:\data1.xls";
print data=data1 label;
run;
ods html close;
当然你可以把上面的写个宏
已有 1 人评分热心指数 收起 理由
crackman + 1 鼓励积极发帖讨论

总评分: 热心指数 + 1   查看全部评分

7
shijz03 发表于 2011-4-6 11:42:17
兄弟,关于columns命名,你不如写个VBA,直接在excel里把问题解决就行了...

8
priss111 发表于 2011-4-6 11:46:52
6# edumetric

谢谢,我试试。

9
priss111 发表于 2011-4-6 11:48:09
7# shijz03

谢谢,我不会写VBA(excel里的宏?),编程能力很菜,正在学习中...

10
edumetric 发表于 2011-4-6 11:49:19
用R的话,你可以把你的变量的名字改为中文
例如你的数据是data
colnames(data)=c("中文变量1“,”中文变量2“...)
write.table(data,file="F:\data.xls",sep="\t",quote=F,row.names=F)
你可以试试看

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-1 07:09