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

[文本处理] 批处理如何统计txt文本每一行出现过的次数?

本帖最后由 pcl_test 于 2016-9-3 15:21 编辑

有一份文本数据要知道其中每一行所出现过的次数,求批处理代码

例如:
01 02 03 04 05 06
01 02 03 04 05 07
01 02 03 04 05 08
01 02 03 04 05 09
01 02 03 04 05 10
01 02 03 04 05 07
01 02 03 04 05 08
01 02 03 04 05 08
01 02 03 04 05 09
01 02 03 04 05 10

批处理后保存为文本:
01 02 03 04 05 06   出现1次
01 02 03 04 05 07   出现2次
01 02 03 04 05 08   出现3次
01 02 03 04 05 09   出现2次
01 02 03 04 05 10   出现2次
01 02 03 04 05 07   出现2次
01 02 03 04 05 08   出现3次
01 02 03 04 05 08   出现3次
01 02 03 04 05 09   出现2次
01 02 03 04 05 10   出现2次

本帖最后由 qzwifi 于 2012-4-14 23:33 编辑

多谢各位大哥!

TOP

  1. @echo off&setlocal enabledelayedexpansion
  2. for /f "delims=" %%a in ('sort a.txt') do (
  3.    if %%a neq !last! (
  4.       if defined last echo !last!=!n! 次
  5.       set n=
  6.    )
  7.    set /a n+=1
  8.    set last=%%a
  9. )
  10. echo !last!=!n! 次
  11. pause
复制代码

TOP

  1. gawk "{a[$0]++}END{for(i in a)print i\" shows \"a[i]\" times\"}" a.txt
复制代码

TOP

谢谢 yangfengoo ,这个保存的结果会带路径,而且速度非常慢。能否再改进下呢?

TOP

>new.txt (for /f "tokens=*" %%a in (test.txt) do for /f "tokens=3" %%b in ('find /c "%%a" "test.txt"') do echo %%a 出现%%b次)

TOP

返回列表