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

[其他] 【已解决】gawk第三方工具:如何赋予变量?

本帖最后由 思想之翼 于 2023-7-14 07:30 编辑

下列代码用于:删除文本右侧最小数值的行
http://www.bathome.net/thread-66798-1-1.html
  1. gawk -v min="10000000000" "NR==FNR {min=min>$2?$2:min} NR>FNR && $2!=min" 1.txt 1.txt > 2.txt
复制代码
该代码用如下方式赋予变量,出现错误,如何解决?
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /l %%f in (1000001,1,1000002) do (
  4.     set p=%%f
  5.     gawk -v min="10000000000" "NR==FNR {min=min>$2?$2:min} NR>FNR && $2!=min" d:\JZ\!p:~1!\1.txt d:\JZ\!p:~1!\1.txt > d:\JZ\!p:~1!\2.txt
  6. )
  7. endlocal
  8. pause
复制代码
出错显示:
gawk: cmd. 1ine:1: NR==FNR (min=min>$2?$2:min} NR>FNR && $2\JZ\000001\1.txt d:\JZ\000001\1.txt
gawk: cmd. 1ine:1: backslash not last character on line
gawk: cmd. 1ine:1: NR==FNR (min=min>$2?$2:min} NR>FNR && $2\JZ\000001\1.txt d:\JZ\000001\1.txt
gawk: cmd. 1ine:1: syntax error

本帖最后由 77七 于 2023-7-14 06:38 编辑

在gawk命令中 的 ”!“ 前加个 “^” 转义
  1. gawk -v min="10000000000" "NR==FNR {min=min>$2?$2:min} NR>FNR && $2^!=min"
复制代码
1

评分人数

bat小白,请多指教!谢谢!

TOP

顶楼脚本没有考虑其它特殊情况。
比如,如果 1.txt 包含有空行,min值为空,脚本会失效
如果必须考虑有空行的情况,可以这样:
  1. gawk -v min=10000000000 "NR==FNR && $0!~/^$/ {min=min>$2?$2:min} NR>FNR && $2!=min" 1.txt 1.txt > 2.txt
复制代码
这个时候开启变量延迟,需要转义的特殊字符就比较多了(!^都要转义)
转义不仅麻烦,脚本变得也更不易读。

可以这样:
  1. @echo off
  2. for /l %%f in (1000001,1,1000002) do (
  3.     setlocal enabledelayedexpansion
  4.     set "p=%%f"
  5.     for /f "delims=" %%i in ("d:\JZ\!p:~1!") do (
  6.         endlocal
  7.         gawk -v min=10000000000 "NR==FNR && $0!~/^$/ {min=min>$2?$2:min} NR>FNR && $2!=min" %%i\1.txt %%i\1.txt > %%i\2.txt
  8.     )
  9. )
  10. pause
复制代码
2

评分人数

TOP

返回列表