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

[文本处理] 【已解决】如何用gawk统计文本记录数值的出现次数

[复制链接]
发表于 2023-7-12 05:33:42 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2023-7-12 09:05 编辑

文本1.txt记录数值如下:
331 445 550 567
008 023 327 550 689
142 350 331 449 550 653

如何用gawk ,统计1.txt记录数值的出现次数,统计结果写入2.txt ?

文本2.txt 记录格式为:
331        2
445        1
550        3
567        1
008        1
023        1
327        1
689        1
142        1
350        1
449        1
653        1
  1. gawk "{for(i=1;i<=NF;i++)a[$i]++}END{for(j in a)print j,a[j]}" 1.txt>2.txt
复制代码
注:下列代码只适用 待统计文本 为一列数据
  1. gawk "{a[$0]++}END{for(j in a)print j,a[j]}" 1.txt>2.txt
复制代码
http://bbs.bathome.net/thread-25608-1-1.html

评分

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

查看全部评分

发表于 2023-7-12 10:25:08 | 显示全部楼层
本帖最后由 qixiaobin0715 于 2023-7-12 10:29 编辑

不用第三方,小批量,数值个数(重复的不做统计)最好不要超过8000:
  1. @echo off
  2. for /f "delims=" %%i in (1.txt) do for %%j in (%%i) do set /a _%%j+=1
  3. (for /f "tokens=1,2 delims=_=" %%k in ('set _') do echo,%%k        %%l)>2.txt
  4. pause
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

发表于 2023-7-12 11:42:57 | 显示全部楼层
回复 1# 思想之翼


单列数据.bat
  1. powershell "Get-Content '1.txt' | Group-Object | ForEach-Object {$_.Name + ' ' + $_.Count} | Out-File '2.txt'"
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 乐于助人

查看全部评分

发表于 2023-7-12 11:43:22 | 显示全部楼层
回复 1# 思想之翼


多行数据.bat
  1. powershell "(Get-Content '1.txt').Split('`n').Split('') | Group-Object | ForEach-Object {$_.Name + ' ' + $_.Count} | Out-File '2.txt'"
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 乐于助人

查看全部评分

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

本版积分规则

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

GMT+8, 2026-3-17 00:47 , Processed in 0.019924 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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