楼主: histidine
3381 3

[问答] 把infile选项中dsd的引号改成分割号 [推广有奖]

  • 0关注
  • 0粉丝

本科生

55%

还不是VIP/贵宾

-

威望
0
论坛币
1090 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
75 点
帖子
78
精华
0
在线时间
119 小时
注册时间
2007-11-22
最后登录
2025-1-5

楼主
histidine 发表于 2014-6-8 06:42:06 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
最近处理一些数据是长成这个样子的
hr1269-110,399109,|110|,|H,R,1269|
s1547-110,742881,|110|,|S,1547|
hr915-111,992675,|111|,|H,R.915|

如果他是这样,就简单多了
hr1269-110,399109,“110”,“H,R,1269”
s1547-110,742881,"110“,”S,1547“
hr915-111,992675,"111","H,R,915"

所以请问各位大虾在读数据的时候,如果数据中的变量不是由引号(”)来区分,而是用分割号(|),我可以怎么修改dsd的性质,程序能够简单的阅读这样的数据呢?多谢多谢

二维码

扫码加我 拉你入群

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

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

关键词:infile file NFI DSD 请问各位大虾 程序

沙发
角尖 发表于 2014-6-8 17:03:14
是不是用dlm=“|”?

藤椅
婴骨 发表于 2014-6-8 23:33:32
对于这样的数据,我会用compress去掉最后碍眼的字符。
板凳等其他更优解~

filename test 'E:\temp\test.txt';
data test;
infile test   dsd missover truncover;
input a1 :$10. a2 a3$ a4 & :$10.;
a3=compress(a3,'|');
a4=compress(a4,'|');
run;

板凳
mingfeng07 学生认证  发表于 2014-6-9 16:05:13
  1. data a;
  2. infile datalines dlm=',|.';/*dlm='分隔符'*/
  3. input a $ b c d $ e $ f;
  4. cards;
  5. hr1269-110,399109,|110|,|H,R,1269|
  6. s1547-110,742881,|110|,|S,1547|
  7. hr915-111,992675,|111|,|H,R.915|
  8. ;
  9. run;
复制代码

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

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