标题: [文本处理] [已解决]批处理如何将txt文本按每行ip地址的第一段数字从小到大排序 [打印本页]
作者: hnldwhm52 时间: 2014-10-6 13:06 标题: [已解决]批处理如何将txt文本按每行ip地址的第一段数字从小到大排序
本帖最后由 pcl_test 于 2016-11-18 17:35 编辑
老师们节日期间好!!
有文本文件 1.txt 内容如下:
1.txt
78.39.178.2:443
58.20.0.247:1080
76.72.246.166:1080
109.167.201.26:1080
85.185.112.8:1080
59.37.163.176:1080
116.55.19.208:1080
想做一个 批处理 按每行第一数值从小到大排序,输出文本文件 2.txt 内容如下:
2.txt
58.20.0.247:1080
59.37.163.176:1080
76.72.246.166:1080
78.39.178.2:443
85.185.112.8:1080
109.167.201.26:1080
116.55.19.208:1080
请老师指教,谢谢!!
作者: terse 时间: 2014-10-6 13:50
- @echo off&setlocal enabledelayedexpansion
- %1(for /f "tokens=*delims=0" %%i in ('%0 :^|sort') do echo %%i)>2.txt&pause&exit
- for /f "tokens=1*delims=." %%i in (1.txt) do set s=00%%i&echo.!s:~-3!.%%j
复制代码
作者: hnldwhm52 时间: 2014-10-6 14:07
terse 发表于 2014-10-6 13:50
非常感谢 terse 老师节日帮我解答!!!
作者: hfxiang 时间: 2023-5-9 21:44
回复 1# hnldwhm52
尝试了一下用gawk( http://bcn.bathome.net/tool/4.1.0/gawk.exe )也能解决。
直接在命令行窗口执行:- gawk -F"[.:]" "{a[sprintf(\"%02X.%02X.%02X.%02X:%04X\n\",$1,$2,$3,$4,$5)]=$0}END{slen=asorti(a,tA);for(i=1;i<=slen;i++)print a[tA[i]]}" 1.txt>2.txt
复制代码
写进脚本然后执行:- gawk -F"[.:]" "{a[sprintf(\"%%02X.%%02X.%%02X.%%02X:%%04X\n\",$1,$2,$3,$4,$5)]=$0}END{slen=asorti(a,tA);for(i=1;i<=slen;i++)print a[tA[i]]}" 1.txt>2.txt
复制代码
作者: terse 时间: 2023-5-10 19:48
本帖最后由 terse 于 2023-5-11 00:50 编辑
按第一段比较的话 这样也行- gawk -F"[.]" "{a[sprintf(\"%%05d\", $1),NR]=$0}END{j=asorti(a,b);for(i=1;i<=j;i++)print(a[b[i]])}" <a.txt >b.txt
复制代码
补充一个,你们测试一下,看版本是否支持- gawk -F"[.]" "{ a[$1,NR]=$0} END { PROCINFO[\"sorted_in\"]=\"@ind_num_asc\"; for (i in a) print(a[i]) }"<text.txt
复制代码
欢迎光临 批处理之家 (http://bbs.bathome.net/) |
Powered by Discuz! 7.2 |