楼主: mehrwoods
860 6

[问答] 紧急求助 [推广有奖]

  • 0关注
  • 0粉丝

svip3

已卖:179份资源

本科生

31%

(VIP/贵宾)六级

8%

威望
0
论坛币
71308 个
通用积分
0.0001
学术水平
7 点
热心指数
9 点
信用等级
6 点
经验
1151 点
帖子
73
精华
0
在线时间
67 小时
注册时间
2008-2-11
最后登录
2025-5-26

楼主
mehrwoods 发表于 2015-9-10 14:38:50 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
附件的EXCEL文件导入SAS9.3中文版后,在执行后续处理时,不能用where进行筛选。
例如用import后,执行Print
proc print data=.....;
  where trans_type="代收";
run;
结果一个观测值也显示不出来。where acct_prov=....也显示0个观测。

急求高人解惑!! SAS数据集.rar (743 Bytes) 本附件包括:
  • test.sas7bdat
二维码

扫码加我 拉你入群

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

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

关键词:紧急求助 急求助 import Where print import 中文版 EXCEL where

沙发
mehrwoods 发表于 2015-9-10 15:12:56
有人能帮忙么?自己先顶起

藤椅
learsaas 发表于 2015-9-10 15:44:16
上传sas数据集,才能找到原因

板凳
mehrwoods 发表于 2015-9-10 16:56:18
SAS数据集已经上传(直接上传不了,压缩了一下)。
自己已经发现原因,在import的时候,dbms=excel写成了dbms=xlsx。
现在的问题是,为什么dbms=xlsx,貌似数据能导入,但后续的操作会出错?求解惑!!

报纸
learsaas 发表于 2015-9-11 10:58:38
看过你的数据了,你的sas数据集trans_type变量中含有不可打印的字符,因为是不可打印,所以你肉眼看不出来。
解决方法:
方法一:把不可打印字符剔除。可用正则表达式替换。
方法二:=表达式替换成包含。
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
mehrwoods + 1 + 1 + 1 精彩帖子

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

地板
Tigflanker 发表于 2015-9-11 11:10:35
接楼上用正则替换所有白空格为普通空格:
  1. prx = prxparse('s/\s/ /');
  2. call prxchange(prx,-1,你的变量名);
复制代码

7
learsaas 发表于 2015-9-11 11:41:48
呵呵,谢谢接我的话题。你最好看看附件中的不可打印的字符(非/s哦)。加油。

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-29 18:22