楼主: halozhangyang
2414 2

[编程问题求助] 关于数据批量读取的问题 [推广有奖]

  • 0关注
  • 0粉丝

初中生

23%

还不是VIP/贵宾

-

威望
0
论坛币
3 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
56 点
帖子
5
精华
0
在线时间
15 小时
注册时间
2012-4-22
最后登录
2015-5-14

楼主
halozhangyang 学生认证  发表于 2014-11-13 21:58:24 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
现在我有大量txt文件,每个文件是一天的数据,我需要将每个文件依次读取然后处理后append。问题出现在读取部分
文件名是有规律的,为 ABCD-YYYYMMDD.txt格式,后面YYYYMMDD为时间。我写了这样的程序,发现Stata什么都没做= =data editor是空的。

forvalue i=1/10{
gen date=`i'+7305
format date %td
gen year=year(date)
gen month=month(date)
gen day=day(date)
tostring year month day,replace
replace month=substr("0"+month,-2,2)
replace day=substr("0"+day,-2,2)
gen date1=year+month+day
*生成了文本格式的日期YYYYMMDD
infile ABCD-`date1'.txt,clear
save date_`i'.dta
}


1.是不是我不应该用gen应该用scalar?但是用scalar的话tostring要求必须有variable
2.最后infile运行的时候总是告诉我file ABCD-.txt not found 是什么原因呢?是不是因为clear,如果去掉clear,那么又会显示
you must start with an empty dataset




在这里跪谢了!
二维码

扫码加我 拉你入群

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

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

关键词:tostring Variable forvalue replace dataset STATA 数据 导入 批量

沙发
ermutuxia 发表于 2014-11-19 17:34:01
cd "d:\test\"
local filelist: dir . files "*.txt"
local a 1
foreach x of local filelist {
        infile using `x', tab clear
        save file`a'.dta
        local a = `a' + 1

}

use file1.dta, clear
local a=`a'-1
forvalue i=2 /`a' {
   append using file`i'
}
已有 1 人评分论坛币 学术水平 热心指数 收起 理由
crystal8832 + 12 + 1 + 1 热心帮助其他会员

总评分: 论坛币 + 12  学术水平 + 1  热心指数 + 1   查看全部评分

藤椅
halozhangyang 学生认证  发表于 2014-11-20 22:44:57
ermutuxia 发表于 2014-11-19 17:34
cd "d:\test\"
local filelist: dir . files "*.txt"
local a 1
太谢谢了!我去试一下!

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

本版微信群
加好友,备注jltj
拉您入交流群
GMT+8, 2025-12-24 15:04