24小时热门版块排行榜    

查看: 2232  |  回复: 21
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

liuhaoke

新虫 (初入文坛)

[求助] 如何批量提取多个文件中第三列的部分数据并求和输出?

原数据文件示例如下:
0       456    30
1       437    20
2       420    40
3       380    10
4       370    0
5       340    0
6       310    50
7       260    20
8       240    0
我要找到文件中从第三列第一行数据开始到非0行结束,接着对这第三列的几行(行数未知)数据求和,并把结果命名为T1输出;
然后接着往下找,还是到非0行结束(每个文件数据0的位置不一样),接着对这次找到的几行数据(第三列)求和,把结果命名为T2输出;
以此类推。
这是每个文件的,这样的文件有几百个,希望批量处理,并把文件名加上。处理结果需要样式示例如下:
文件名    T1    T2     T3     T4     T5     T6
文件1     100   70     
文件2
文件3
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : 数据文件.rar
  • 2012-05-09 07:54:52, 67.23 K

» 收录本帖的淘帖专辑推荐

source

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

【答案】应助回帖


感谢参与,应助指数 +1
liuhaoke: 金币+1, 有帮助 2012-05-11 16:46:43
好吧 使用matlab求解
CODE:
fuction f=doallfile()
order=64;
for i=1:10
     order=order+1;
     inputfile=strcat('name',num2str(i),'.txt');//处理的是name1.txt文件
     doone(inputfile,num2str(order));
end
function f=doone(name,order)
data=load(name);
d3=data(:,3);
n=length(d3);
sum=0;
number=1;
for i=1:n
    if(d3(i)~=0)
        sum=sum+d3(i);
   elseif(sum~=0)
       ouputfile=strcat(order,num2str(number),'.txt');
       save(outputfile,'sum','-ascii') ;
       sum=0;
      number=number+1;
  end
end
end
end

» 本帖已获得的红花(最新10朵)

7楼2012-05-10 09:15:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 22 个回答

lt292

金虫 (正式写手)

Holy Shit

【答案】应助回帖


感谢参与,应助指数 +1
liuhaoke: 金币+1, 有帮助 2012-05-09 17:49:36
shell 有工具cut可以提取第三列,然后重定向到新文件
cut的用法lz可以直接man cut或者看看参考书
然后打开新文件,写一个循环,输出数据并生成T系列的文件
个人感觉shell脚本可以实现
不过我对shell不是很熟,不能帮lz搞定,希望lz自己查阅一下资料
记忆中的颜色,慢慢褪去,变成一缕缕的黑丝,最终消失在茫茫的空白里,一去不返```
2楼2012-05-09 09:14:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liuhaoke

新虫 (初入文坛)

引用回帖:
3楼: Originally posted by lijie169 at 2012-05-09 13:45:21:
bb太少

我还有8个,但是怎么增加悬赏金币呢?请照顾一下新手吧!
4楼2012-05-09 15:27:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liuhaoke

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by lt292 at 2012-05-09 09:14:27:
shell 有工具cut可以提取第三列,然后重定向到新文件
cut的用法lz可以直接man cut或者看看参考书
然后打开新文件,写一个循环,输出数据并生成T系列的文件
个人感觉shell脚本可以实现
不过我对shell不是很熟, ...

但是我是新手,不知道shell,现学?
5楼2012-05-09 15:29:22
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0703化学调剂 +11 妮妮ninicgb 2026-03-15 15/750 2026-03-21 19:15 by ColorlessPI
[考研] 0703化学调剂 +4 妮妮ninicgb 2026-03-21 4/200 2026-03-21 18:39 by 学员8dgXkO
[考研] 0703化学297求调剂 +3 Daisy☆ 2026-03-20 3/150 2026-03-21 17:45 by ColorlessPI
[考研] 299求调剂 +4 某某某某位 2026-03-21 4/200 2026-03-21 16:30 by barlinike
[考研] 能源材料化学课题组招收硕士研究生8-10名 +5 脱颖而出 2026-03-16 15/750 2026-03-21 10:16 by 脱颖而出
[考研] 265求调剂 +9 梁梁校校 2026-03-17 9/450 2026-03-21 02:17 by JourneyLucky
[考研] 328求调剂,英语六级551,有科研经历 +4 生物工程调剂 2026-03-17 8/400 2026-03-21 02:12 by JourneyLucky
[考研] 330求调剂 +4 小材化本科 2026-03-18 4/200 2026-03-20 23:13 by JourneyLucky
[考研] 304求调剂 +7 司空. 2026-03-18 7/350 2026-03-20 23:08 by JourneyLucky
[考研] 288求调剂 +16 于海海海海 2026-03-19 16/800 2026-03-20 22:28 by JourneyLucky
[考研] 085600材料与化工 +8 安全上岸! 2026-03-16 8/400 2026-03-20 22:13 by luoyongfeng
[考研] 药学383 求调剂 +3 药学chy 2026-03-15 5/250 2026-03-20 22:11 by 云游重阳
[考研] 350求调剂 +5 weudhdk 2026-03-19 5/250 2026-03-20 22:04 by luoyongfeng
[考研] 中南大学化学学硕337求调剂 +3 niko- 2026-03-19 6/300 2026-03-20 21:58 by luoyongfeng
[考研] 0703化学调剂 +3 妮妮ninicgb 2026-03-17 3/150 2026-03-18 10:29 by macy2011
[考研] 302求调剂 +4 小贾同学123 2026-03-15 8/400 2026-03-17 10:33 by 小贾同学123
[论文投稿] 有没有大佬发小论文能带我个二作 +3 增锐漏人 2026-03-17 4/200 2026-03-17 09:26 by xs74101122
[考研] 一志愿,福州大学材料专硕339分求调剂 +3 木子momo青争 2026-03-15 3/150 2026-03-17 07:52 by laoshidan
[考研] 机械专硕325,寻找调剂院校 +3 y9999 2026-03-15 5/250 2026-03-16 19:58 by y9999
[考研] 304求调剂 +5 素年祭语 2026-03-15 5/250 2026-03-16 17:00 by 我的船我的海
信息提示
请填处理意见