SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 705|回复: 2
打印 上一主题 下一主题

关于DLM的一个问题

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2004-4-19 21:36:41 | 只看该作者

关于DLM的一个问题

如果在我的数据中使用一个符号做分割符,例如DLM=‘*’,但连续两个**则要作为数据读进SAS。应该怎么办。
例如
1*2**2,需要把1读到一个变量中,2**2读到另一个变量中。

多谢
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2004-4-20 08:48:16 | 只看该作者

我有一个办法

[quote="smartie":77e3d]如果在我的数据中使用一个符号做分割符,例如DLM=‘*’,但连续两个**则要作为数据读进SAS。应该怎么办。
例如
1*2**2,需要把1读到一个变量中,2**2读到另一个变量中。

多谢[/quote:77e3d]

如果你的文件不是特别大的话,先用写字板打开,把“**”替换成另外一个符号(当然,选择的符号要和文件中其他数据区别),然后把“*”替换成其它分隔符,最后把“**”替换回去。~~呵呵,似乎有点复杂。
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2004-4-20 23:53:35 | 只看该作者
看来只能用列表模式了,如果你的数据整齐的话
data tmp;
infile cards;
input a 1 b$ 3-6;
cards;
1*2**2
;run;

或者把整个当成字符读入,然后用字符函数把它分开
data tmp;
infile cards;
input a$;
b1=input(substr(a,1,index(a,'*')-1),8.);
b2=substr(a,index(a,'*')+1,length(a));
cards;
1*2**2
;run;
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2025-1-9 11:12 , Processed in 0.172710 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表