24小时热门版块排行榜    

CyRhmU.jpeg
南方科技大学公共卫生及应急管理学院2025级博士研究生招生报考通知
查看: 1980  |  回复: 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 的主题更新
信息提示
请填处理意见