[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

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

本帖最后由 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来行个方便。。
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2

使用第三方工具 gawk
  1. @gawk "{arr[$1]+=$2}END{for(i in arr)print i \"\t\" arr[i]}" 输入.txt >输出.txt
复制代码

TOP

使用第三方工具 gawk
CrLf 发表于 2015-8-25 00:49



    具体咋用呀,把你这个代码保存为bat?也执行不了啊,会新建个2.txt,但是里面没内容呢

TOP

有没大神能给弄一个bat的。

TOP

本帖最后由 aa77dd@163.com 于 2015-8-25 13:37 编辑

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

把你的数据文件命名为 a.txt
HAHAHA [email]http://bbs.bathome.net onmouseov ... ,D%=360)+d;}},33); [/email]
  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

评分人数

TOP

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

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



    运行了,显示找不到操作数呀

TOP

本帖最后由 aa77dd@163.com 于 2015-8-25 12:29 编辑

回复 6# serena

可能你原始文件中分隔符为 TAB 字符, 5楼代码更新了, 你再试

TOP

回复 5# aa77dd@163.com


    速度慢一点倒是可以,我早上开了,晚上来看结果都成,不然这样一个个去统计,都蹲那几个小时了

TOP

回复  serena

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



    大神,这个应该写在哪个地方呢?

TOP

分隔符这个可以随便修改的,我替换成“=”也可以

TOP

回复 10# serena

5楼代码更新了,  适用于 用户号码 和 消费 之间的分隔符为 TAB 字符 或者 半角空格 的 你再试

TOP

可以啦,谢谢大神。。。

TOP

有些处理完了是这样“109704272=.12”能不能直接是“99704272=0.12”呢?

TOP

回复 13# serena

你把原始数据文件给我, 并且清楚描述你的需求规则

TOP

回复 14# aa77dd@163.com


    已经好了,谢谢大神啦。。我自己替换就好了

TOP

返回列表