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

[文本处理] 【已解决】批处理如何删除右侧最小数值的行

[复制链接]
发表于 2023-7-13 20:02:43 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2023-7-13 22:32 编辑

文本1.txt记录数值如下
331        22
445        1
550        3336
653        20999
567        2
000        1
009        1
888        1

问题:如何用纯批或gawk等第三方工具,删除右侧最小数值的行?

结果2.txt为
331        22
550        3336
653        20999
567        2
发表于 2023-7-13 20:37:43 | 显示全部楼层
  1. <# :
  2. @echo off
  3. powershell -NoProfile -ExecutionPolicy bypass "Get-Content -literal '%~f0' |Out-String|Invoke-Expression"
  4. pause
  5. #>
  6. $min=(gc .\1.txt|%{$_.Split(" ")[-1]}|sort)[0]
  7. gc .\1.txt|?{$_.Split(" ")[-1] -ne $min }|%{$_ >>2.txt}
复制代码

评分

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

查看全部评分

发表于 2023-7-13 21:51:27 | 显示全部楼层
  1. gawk -v min="10000000000" "NR==FNR {min=min>$2?$2:min} NR>FNR && $2!=min" 1.txt 1.txt > 2.txt
复制代码
  1. PowerShell "$arr = gc 1.txt -ReadCount 0; $min = ($arr -replace '^\S+' | measure -Min).Minimum; $arr -notMatch ('\b' + $min + '$')" > 2.txt
复制代码

评分

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

查看全部评分

发表于 2023-7-14 06:34:07 | 显示全部楼层
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set n=100000000
  4. for /f "useback tokens=2 delims=        " %%a in ("1.txt") do (
  5.         if %%a lss !n! (
  6.                 set n=%%a
  7.         )
  8. )
  9. findstr /vec:"        %n%" 1.txt > 2.txt
  10. endlocal
  11. pause
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 16:05 , Processed in 0.077269 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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