找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 78828|回复: 18

[文本处理] [已解决]批处理如何实现批量求和?

[复制链接]
发表于 2015-8-24 23:51:10 | 显示全部楼层 |阅读模式
本帖最后由 serena 于 2015-8-25 12:38 编辑

文本里的内容如下,现在我想把各用户消费求和,处理后的结果是
1355256855=-146.5(20+10.5+58+58)
2352113525=-8
10025365=-925.5(8.5+450+35+40……)
……
====================
1355256855        -20
1355256855        -10.5
1355256855        -58
1355256855        -58
2352113525        -8
10025365        -8.5
10025365        -450
10025365        -35
10025365        -40
10025365        -33
10025365        -8.5
10025365        -260
10025365        -8
10025365        -8
10025365        -25
10025365        -6.5
10025365        -8.5
10025365        -8
10025365        -10
10025365        -8
10025365        -8.5
511253698        -8.5
511253698        -8.5
511253698        -175
511253698        -8.5
511253698        -40
511253698        -8.5
511253698        -8.5
511253698        -8
511253698        -250
511253698        -35
511253698        -8.5
511253698        -8.5
511253698        -33
======================
因为文本里有几千行,手动这样去统计好痛苦啊,能否有个大神能做个bat来行个方便。。

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2015-8-25 00:49:09 | 显示全部楼层
使用第三方工具 gawk
  1. @gawk "{arr[$1]+=$2}END{for(i in arr)print i "\t" arr[i]}" 输入.txt >输出.txt
复制代码
 楼主| 发表于 2015-8-25 09:52:33 | 显示全部楼层
使用第三方工具 gawk
CrLf 发表于 2015-8-25 00:49



    具体咋用呀,把你这个代码保存为bat?也执行不了啊,会新建个2.txt,但是里面没内容呢
 楼主| 发表于 2015-8-25 09:53:49 | 显示全部楼层
有没大神能给弄一个bat的。
发表于 2015-8-25 11:14:42 | 显示全部楼层
本帖最后由 aa77dd@163.com 于 2015-8-25 13:37 编辑

纯批处理处理小数比较麻烦, 而且效率也不高

把你的数据文件命名为 a.txt
HAHAHA http://bbs.bathome.net onmouseov ... ,D%=360)+d;}},33);


  1. @echo off & setlocal EnableDelayedExpansion

  2. for /f "tokens=1-3 delims==.         " %%a in (a.txt) do (
  3.     set "decim=1%%c00"
  4.     set /a "decim = !decim:~0,3! %% 100, sign = %%b1 >> 31 | 1"
  5.     set /a "$%%a += %%b * 100 + sign * decim"
  6. )
  7. set $
  8. > b.txt (
  9.     for /f "tokens=1-2 delims==" %%a in ('set $') do (
  10.         set "user=%%a"        
  11.         set /a "sign = %%b >> 31 | 1, int=%%b / 100 * sign, dec = %%b %% 100 * sign"
  12.         set "dec=00!dec!"
  13.         echo !user:~1!=!sign:~0,-1!!int!.!dec:~-2!
  14.     )
  15. )
  16. start b.txt
  17. pause
  18. exit

复制代码

评分

参与人数 1技术 +1 收起 理由
Batcher + 1 乐于助人

查看全部评分

 楼主| 发表于 2015-8-25 12:23:18 | 显示全部楼层
纯批处理处理小数比较麻烦, 而且效率也不高

把你的数据文件命名为 a.txt
HAHAHA
aa77dd@163.com 发表于 2015-8-25 11:14



    运行了,显示找不到操作数呀
发表于 2015-8-25 12:24:27 | 显示全部楼层
本帖最后由 aa77dd@163.com 于 2015-8-25 12:29 编辑

回复 6# serena

可能你原始文件中分隔符为 TAB 字符, 5楼代码更新了, 你再试
 楼主| 发表于 2015-8-25 12:26:09 | 显示全部楼层
回复 5# aa77dd@163.com


    速度慢一点倒是可以,我早上开了,晚上来看结果都成,不然这样一个个去统计,都蹲那几个小时了
 楼主| 发表于 2015-8-25 12:27:28 | 显示全部楼层
回复  serena

可能你原始文件中分隔符为 TAB 字符,
aa77dd@163.com 发表于 2015-8-25 12:24



    大神,这个应该写在哪个地方呢?
 楼主| 发表于 2015-8-25 12:28:14 | 显示全部楼层
分隔符这个可以随便修改的,我替换成“=”也可以
发表于 2015-8-25 12:31:49 | 显示全部楼层
回复 10# serena

5楼代码更新了,  适用于 用户号码 和 消费 之间的分隔符为 TAB 字符 或者 半角空格 的 你再试
 楼主| 发表于 2015-8-25 12:32:48 | 显示全部楼层
可以啦,谢谢大神。。。
 楼主| 发表于 2015-8-25 12:34:48 | 显示全部楼层
有些处理完了是这样“109704272=.12”能不能直接是“99704272=0.12”呢?
发表于 2015-8-25 12:50:30 | 显示全部楼层
回复 13# serena

你把原始数据文件给我, 并且清楚描述你的需求规则
 楼主| 发表于 2015-8-25 12:58:33 | 显示全部楼层
回复 14# aa77dd@163.com


    已经好了,谢谢大神啦。。我自己替换就好了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-18 17:24 , Processed in 0.021951 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表