24小时热门版块排行榜    

Znn3bq.jpeg
查看: 2268  |  回复: 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的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

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的回帖

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的回帖

wangybcn

禁虫 (正式写手)

感谢参与,应助指数 +1
本帖内容被屏蔽

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

9楼2012-05-10 22:37:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wangybcn

禁虫 (正式写手)

本帖内容被屏蔽

10楼2012-05-10 22:38:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

lijie169

铜虫 (著名写手)

bb太少

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

3楼2012-05-09 13:45:21
已阅   回复此楼   关注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的回帖

liuhaoke

新虫 (初入文坛)

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

我现在有13个金币了,可以都悬赏,只要能解决问题,先送你花一朵以表诚意。
6楼2012-05-09 15:37:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

【答案】应助回帖

对上面那个程序需要解释一下: 处理的是name1.txt~name10.txt的文件,如果需要改变的话,修改name 和i 的值就可以了,保存的是以A开始的,第一次非0连续的变量的是A1.txt 第一个文件的非0和都是以A开头,然后依次类推,还有没有运行过 。。。
8楼2012-05-10 09:19:11
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 liuhaoke 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求助调剂,跨调 +11 X十甫寸Y 2026-04-11 11/550 2026-04-11 23:49 by 学zh
[考研] 344 材料专业 求调剂211 无地域要求 +5 hualkop 2026-04-11 5/250 2026-04-11 23:13 by 852137818
[考研] 一志愿211,0703化学305分求调剂 +26 严西西戏 2026-04-06 33/1650 2026-04-11 23:01 by 314126402
[考研] 电子信息279求调剂,有书读就行 +8 wwwooden 2026-04-08 11/550 2026-04-11 20:22 by cq2548
[考研] 求调剂,一志愿大连理工大学354分 +5 雨声余生 2026-04-11 6/300 2026-04-11 16:12 by 雨声余生
[基金申请] 山东省基金2026 +4 jerry681 2026-04-08 5/250 2026-04-11 13:59 by laobibibi
[考研] 材料专业344求调剂 +16 hualkop 2026-04-10 21/1050 2026-04-10 17:28 by laoshidan
[考研] 085404 298分求调剂 +10 呼啦呼啦呼呼呼 2026-04-10 11/550 2026-04-10 16:44 by wangy0907
[考研] 282,电气工程专业,求调剂,不挑专业 +9 jggshjkkm 2026-04-10 9/450 2026-04-10 14:55 by 逆水乘风
[考研] 材料专硕调剂 +16 哈哈哈吼吼吼哈 2026-04-07 17/850 2026-04-09 21:16 by wutongshun
[考研] 085801 总分275 本科新能源 求调剂 +8 bradoner 2026-04-08 9/450 2026-04-09 13:43 by only周
[考研] 308求调剂 +17 墨墨漠 2026-04-06 17/850 2026-04-09 09:25 by 壹往無前
[考研] 353求调剂 +8 晴空万里air 2026-04-07 8/400 2026-04-09 00:18 by GouQ
[考研] 287求调剂 +6 Fnhc 2026-04-07 6/300 2026-04-08 10:05 by xingguangj
[考研] 326分,一志愿沪9,求生物学调剂 +4 刘墨墨 2026-04-05 4/200 2026-04-08 06:22 by lijunpoly
[考研] 工科 22408 267求推荐 +4 wanwan00 2026-04-05 5/250 2026-04-06 22:47 by chenzhimin
[考研] (调剂)一志愿报考哈尔滨工业大学0857资源与环境专业378分考生 +7 狠狠加油 2026-04-05 8/400 2026-04-06 16:52 by momo皓
[考研] 085405软件工程301分求调剂,专硕可跨专业,四六级已过 +3 静静想想 2026-04-05 3/150 2026-04-06 15:23 by nepu_uu
[考研] 377求调剂 +6 by.ovo 2026-04-05 6/300 2026-04-05 22:18 by dongzh2009
[考研] 求调剂 +7 张.1 2026-04-05 7/350 2026-04-05 20:40 by 啵啵啵0119
信息提示
请填处理意见