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

[文本处理] [已解决]批处理如何统计重复行并排序?

本帖最后由 necnec1 于 2021-10-5 10:08 编辑

BSZXX210827
BSZXX210827
BSZXX210827
BSZXX210828
BSZXX210829
BSZXX210830
BSZXX210831
BSZXX210831
BSZXX210831
一个文本文件AA.TXT  内容如上  重复的行 能不能统计出 重复了多少次  并按照重复的次数从大到小的排序
BSZXX210828  1次
BSZXX210829  1次
BSZXX210830  1次
BSZXX210827   3次
BSZXX210831  3次
最后结果像这样

回复 1# necnec1
  1. gawk "BEGIN {PROCINFO [\"sorted_in\"]=\"@val_num_asc\"}{a[$0]++}END{for(i in a)print i,a[i]}" 1.txt > 2.txt
复制代码
http://bcn.bathome.net/s/tool/index.html?key=gawk
1

评分人数

我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%a in (aa.txt) do set /a %%a+=1
  4. set BSZXX
  5. pause
复制代码

TOP

谢谢楼上的各位 问题已解决

TOP

回复 4# qixiaobin0715


    严格来说,set命令的结果不是楼主要求的“并按照重复的次数排序”
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%a in (aa.txt) do (
  4. if not defined %%a set %%a=1000
  5. set /a %%a+=1
  6. )
  7. set BSZXX|sort /+13>aa.log
  8. for /f "tokens=1* delims==" %%i in (aa.log) do (
  9. set n=%%j
  10. set n=!n:~1!
  11. set /a n=n
  12. echo,%%i !n!次
  13. )
  14. del aa.log
  15. pause
复制代码

TOP

返回列表