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

[文本处理] 【已解决】BAT如何逐列统计数据出现次数多少,并从多到少排序?

[复制链接]
发表于 2013-12-7 00:37:14 | 显示全部楼层 |阅读模式
有378个txt文本,每个txt数据只有一行,为0-9十个数值的乱序排列,格式为:8 1 9 2 0 6 5 4 7 3 (约定从左到右分别为第1、2、3...10列)
欲:
统计378个txt文本中第1列的数据出现次数多少,并从多到少排序(出现次数相同的,则从小到大排序;出现次数为零的数值,也从小到大排序)
统计378个txt文本中第2列的数据出现次数多少,并从多到少排序(出现次数相同的,则从小到大排序;出现次数为零的数值,也从小到大排序)
...
统计378个txt文本中第10列的数据出现次数多少,并从多到少排序(出现次数相同的,则从小到大排序;出现次数为零的数值,也从小到大排序)

之后,将上述第1列、第2列...第10列的统计排序,合并成一行,存放在新建的txt文本中,格式为:7 5 8 0 6 3 9 1 4 2 2 1 4 5 3 7 8 9 0 6 ...

恳望得到帮助!

评分

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

查看全部评分

发表于 2013-12-7 17:20:22 | 显示全部楼层
  1. @echo off&setlocal enabledelayedexpansion
  2. for /L %%i in (0,1,9) do for /L %%j in (0,1,9) do set _%%i_%%j=0
  3. for /f "delims=" %%i in ('dir /b/a-d *.txt') do (
  4.     for /f "usebackq delims=" %%j in ("%%i") do (
  5.         set n=-1
  6.         for %%a in (%%j) do (
  7.             set /a n+=1
  8.             set /a $!n!_%%a+=1
  9.         )
  10.     )
  11. )
  12. for /L %%i in (0,1,9) do for /L %%j in (0,1,9) do (
  13.     set "str=000!$%%i_%%j!"
  14.     set /a n=9-%%j
  15.     set "$%%i=!$%%i! !str:~-3!#!n!-%%j"
  16. )
  17. set "str="
  18. for /L %%i in (0,1,9) do (
  19.     for /f "tokens=2 delims=-" %%a in ('"(for %%j in (!$%%i!) do @echo %%j)|sort/r"') do (
  20.         set "str=!str!%%a"
  21.     )
  22. )
  23. >new_text.txt echo;!str!
  24. pause
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 非常感谢!运送快速,完美解决问题。

查看全部评分

发表于 2013-12-7 17:53:04 | 显示全部楼层

  1. @echo off&setlocal enabledelayedexpansion
  2. for /l %%a in (1,1,378) do (
  3.     set /p str=<%%a.txt
  4.     set n=0
  5.     for %%b in (!str!) do set /a #!n!.%%b+=1,n+=1
  6. )
  7. for /l %%a in (0,1,9) do (
  8.     for /l %%b in (0,1,9) do (
  9.         set /a m=0
  10.         for /l %%c in (0,1,9) do (
  11.             if !#%%a.%%b!%%c lss !#%%a.%%c!%%b set /a m+=1
  12.         )
  13.     set "!m!=%%b"
  14.     )
  15.     for /l %%i in (0,1,9) do set "echo=!echo!!%%i! "
  16. )
  17. echo,%echo%>new.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 非常感谢!运送快速,完美解决问题。

查看全部评分

 楼主| 发表于 2013-12-7 18:12:25 | 显示全部楼层
感谢2位大师的鼎力帮助!
发表于 2013-12-8 15:28:34 | 显示全部楼层
本帖最后由 apang 于 2013-12-8 15:38 编辑

纯练习
  1. @set @n=1 //&dir /a-d/b *.txt|cscript -nologo -e:jscript "%~0" &pause&exit /b
  2. fso = new ActiveXObject("Scripting.FileSystemObject");
  3. a = new Array();b = new Array();s = new Array();
  4. for (i=0;i<10;i++) {a[i] = ""};
  5. while (!WSH.StdIn.AtEndOfStream) {
  6.     f = WSH.StdIn.ReadLine();
  7.     arr = fso.OpenTextFile(f).ReadLine().split(" ");
  8.     for (i=0;i<10;i++) {a[i] += arr[i] + " "};
  9. }
  10. for (i=0;i<10;i++) {
  11.     for (j=0;j<10;j++) {
  12.         b[j] = a[i].split(j).length + 1000 + (9-j).toString();
  13.     };
  14.     b.sort(function(x,y){return y-x});
  15.     s[i] = b.join(" ").replace(/\d{4}(\d)/g,
  16.         function(s0,s1){return 9-s1}
  17.     );
  18. };
  19. fso.OpenTextFile("Result.txt",2,true).Write(s.join(" "));
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢帮助!

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 20:15 , Processed in 0.062858 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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