楼主: yanan9256
1518 8

[原创博文] 数据读入时的疑惑 [推广有奖]

  • 1关注
  • 0粉丝

已卖:42份资源

硕士生

72%

还不是VIP/贵宾

-

威望
0
论坛币
145 个
通用积分
0.1200
学术水平
3 点
热心指数
6 点
信用等级
2 点
经验
6980 点
帖子
145
精华
0
在线时间
196 小时
注册时间
2008-10-12
最后登录
2018-9-5

楼主
yanan9256 发表于 2011-10-26 16:46:26 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
请看下面两段程序
  1. data b;
  2. input name $ sex $ region $ date yymmdd10. money;
  3. label name='姓名' sex='性别' region='地区' date='日期' money='金额';
  4. format date yymmdd10.;
  5. cards;
  6. 章文 男 华东 1996-3-20 1099
  7. 亡国铭 男 华东 1996-5-19 39
  8. 童子敏 女 华北 1996-1-5 986
  9. 刘念新 男 东北 1997-10-1 3581
  10. 刘思今 女 华北 1997-4-1 659
  11. 关绍 女 东北 1996-11-5 358
  12. 赵霞 女 东北 1998-9-6 2010
  13. ;
  14. run;
  15. proc print;
  16. run;
复制代码
  1. data b;
  2. length name $8 sex $2 region $4 date money 8;
  3. informat date yymmdd10. ;
  4. format date date9.;
  5. label name='姓名' sex='性别' region='地区' date='日期' money='金额';

  6. input name sex region date money;


  7. cards;
  8. 章文 男 华东 1996-3-20 1099
  9. 亡国铭 男 华东 1996-5-19 39
  10. 童子敏 女 华北 1996-1-5 986
  11. 刘念新 男 东北 1997-10-1 3581
  12. 刘思今 女 华北 1997-4-1 659
  13. 关绍 女 东北 1996-11-5 358
  14. 赵霞 女 东北 1998-9-6 2010
  15. ;

  16. proc print;
  17. run;
复制代码
这两段程序 对date变量设置的输入格式 都是yymmdd10.
而结果 第一段程序 读入出错 第二段读入正确
请问差别在哪里呢?
二维码

扫码加我 拉你入群

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

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

关键词:数据读入 informat informa Region format money 程序 姓名

沙发
honghejing 发表于 2011-10-26 17:05:14
第一个缺少一个informat

藤椅
dcyhfut 发表于 2011-10-26 19:18:01
我运行的都对啊

板凳
yanan9256 发表于 2011-10-26 21:24:34
honghejing 发表于 2011-10-26 17:05
第一个缺少一个informat
不是在input里面已经 定义了 格式了吗?

还有一个问题是 当在02.input name $ sex $ region $ date : yymmdd10. money;


加上冒号的时候 数据读入就正确了。如何正确理解这些问题呢?

报纸
yanan9256 发表于 2011-10-26 21:25:29
dcyhfut 发表于 2011-10-26 19:18
我运行的都对啊
注意 最后一个变量 可能由于位宽的问题 读错了 例如最后一个值 2010 都成10了

地板
playmore 发表于 2011-10-27 12:53:27
yanan9256 发表于 2011-10-26 21:24
不是在input里面已经 定义了 格式了吗?

还有一个问题是 当在02.input name $ sex $ region $ date : y ...
不加冒号的话,yymmdd10.就变成一个变量名了
而且估计会因为变量名不能含有.而报错
playmore邀请您访问ChinaTeX论坛!!!进入ChinaTeX论坛

7
honghejing 发表于 2011-10-27 13:14:20
yanan9256 发表于 2011-10-26 21:25
注意 最后一个变量 可能由于位宽的问题 读错了 例如最后一个值 2010 都成10了
可以参考base 50题的第一题:An informat is used to translate the calendar date to a SAS date value. The date values are in the form of two-digit values for month-day-year, so the MMDDYY8. informat must be
used. When using an informat with list input, the colon-format modifier is required to correctly associate the informat with the variable name.

8
yanan9256 发表于 2011-10-27 17:43:47
honghejing 发表于 2011-10-27 13:14
可以参考base 50题的第一题:An informat is used to translate the calendar date to a SAS date value. ...
谢谢你啦

9
yanan9256 发表于 2011-10-27 17:45:50
playmore 发表于 2011-10-27 12:53
不加冒号的话,yymmdd10.就变成一个变量名了
而且估计会因为变量名不能含有.而报错
yymmdd10. 是格式的
冒号 用来对变量不同位宽定义统一长度,遇到以下情况停止 下一个空格列 规定长度 行结束
谢谢你

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

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