楼主: CDA网校
751 1

[程序分享] R实现大文本文件数据过滤的方法——CDA人工智能学院 [推广有奖]

管理员

已卖:189份资源

泰斗

4%

还不是VIP/贵宾

-

威望
3
论坛币
125437 个
通用积分
11727.7127
学术水平
278 点
热心指数
286 点
信用等级
253 点
经验
230766 点
帖子
7052
精华
19
在线时间
4401 小时
注册时间
2019-9-13
最后登录
2026-2-6

初级热心勋章

楼主
CDA网校 学生认证  发表于 2021-1-25 08:54:31 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
CDA人工智能学院致力于以优质的人工智能在线教育资源助力学员的DT职业梦想!课程内容涵盖数据分析机器学习深度学习人工智能tensorFlowPyTorch知识图谱等众多核心技术及行业案例,让每一个学员都可以在线灵活学习,快速掌握AI时代的前沿技术。PS:私信我即可获取CDA会员1个月免费试听机会

使用R语言过滤文件数据是很普遍的操作,但有时我们会遇到比较大的文件,这类文件无法全部读入内存处理,需要采用分批读取、分批过滤、拼合结果的办法来解决。下面用一个例子来说明R实现大文件数据过滤的方法。

有个1G的文件sales.txt,存储着大量订单记录,请过滤出AMOUNT字段值在2000和3000之间的记录。该文件的列分割符为“\t”,前几行数据如下:

20180709064615_36027.png

R语言解决方案

con <- file("E:\\sales.txt", "r")
readLines(con,n=1)
result=read.table(con,nrows=100000,sep="\t")
result<-result[result$V4>=2000 & result$V4<=3000,]
while(length(databatch<-read.table(con,header=FALSE,nrows=100000,sep="\t"))!=0) {
databatch<- databatch [databatch$V4>=2000 & databatch$V4<=3000,]
result<-rbind(result,databatch)
}
close(con)

部分计算结果

20180709064621_38125.png

代码解读:

1行:打开文件句柄

2行:丢掉第一行,也就是列名。

3-4行:读入第一批的十万条数据,过滤后存入result。

5-8行:循环读数。每批次读入十万行数据,过滤后的结果追加到result变量,然后再读入下一批次。

9行:关闭文件句柄。

注意事项:

如果是小文件,则只需一句代码就能完成读数据的操作,第一行还可以设置为数据框的列名,但大文件不能这么实现,需要按批次读取数据,第二批的数据就无法将第一行设为列名了,默认列名会是V1、V2、V3…….。

为了实现大文件按批次读数据,必须使用while语句来实现算法,列名的使用也不够方便,这就使整个代码稍显复杂。

替代方案:

同样的算法也可以用Python、集算器、Perl等语言来解决本案例。和R语言一样,这几种语言都可以实现文件数据的过滤以及结构化数据的计算,下面简单介绍集算器和Python的解决方案。

集算器会自动分批处理数据,程序员无需用循环语句手工控制,因此代码非常简洁:

20180709064628_88326.png


cursor是集算器中用于结构化数据计算的数据类型,和数据框的用法差不多,但对大文件和复杂计算更擅长。另外,cursor可以用@t选项将文件的第一行读为列名。

Python的代码结构和R差不多,也是手工控制循环,但python本身缺乏数据框或cursor等结构化数据类型,因此代码更底层些:

result = []
myfile = open("E: \\sales.txt",'r')
BUFSIZE = 10240000
myfile.readline()
lines = myfile.readlines(BUFSIZE)
value=0
while lines:
   for line in lines:
       record=line.split('\t')
       AMOUNT=float(record[3])
       if (AMOUNT>=2000 and AMOUNT<=3000):
result.append(record)
   lines = myfile.readlines(BUFSIZE)
myfile.close()

Python也可以用第三方包来实现上述算法,比如pandas就有类似数据框的结构化数据对象,但pandas对大文件的支持同样有限,很难进一步简化代码。

29C446FFF799701B5098749DB47B5891.jpg


扫码关注CDA公众号,即可获取最新版数据分析题库大全CDA免费精品课70+



二维码

扫码加我 拉你入群

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

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

关键词:文本文件 人工智能 CDA R实现 Tensor

沙发
三重虫 发表于 2021-1-25 16:36:47

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

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