Board logo

标题: [文本处理] [已解决]批处理如何将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

  1. @echo off&setlocal enabledelayedexpansion
  2. %1(for /f "tokens=*delims=0" %%i in ('%0 :^|sort') do echo %%i)>2.txt&pause&exit
  3. 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 )也能解决。
直接在命令行窗口执行:
  1. 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
复制代码
写进脚本然后执行:
  1. 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 编辑

按第一段比较的话 这样也行
  1. 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
复制代码
补充一个,你们测试一下,看版本是否支持
  1. gawk -F"[.]" "{ a[$1,NR]=$0} END { PROCINFO[\"sorted_in\"]=\"@ind_num_asc\"; for (i in a) print(a[i]) }"<text.txt
复制代码





欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2