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

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

本帖最后由 思想之翼 于 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

  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

评分人数

TOP

  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

评分人数

TOP

  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
复制代码
bat小白,请多指教!谢谢!

TOP

返回列表