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

[文本处理] [已解决]批处理如何将txt文本按每行ip地址的第一段数字从小到大排序

[复制链接]
发表于 2014-10-6 13:06:55 | 显示全部楼层 |阅读模式
本帖最后由 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

请老师指教,谢谢!!

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2014-10-6 13:50:31 | 显示全部楼层
  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
复制代码

评分

参与人数 1技术 +1 收起 理由
hnldwhm52 + 1 5

查看全部评分

 楼主| 发表于 2014-10-6 14:07:25 | 显示全部楼层
terse 发表于 2014-10-6 13:50


非常感谢 terse 老师节日帮我解答!!!
发表于 2023-5-9 21:44:10 | 显示全部楼层
回复 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
复制代码
发表于 2023-5-10 19:48:53 | 显示全部楼层
本帖最后由 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
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 21:34 , Processed in 0.018970 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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