标题: [文本处理] [已解决]请问如何使用批处理把文本中第二列的数字按数字大小来排序? [打印本页]
作者: ushit0001 时间: 2019-5-6 10:54 标题: [已解决]请问如何使用批处理把文本中第二列的数字按数字大小来排序?
本帖最后由 ushit0001 于 2019-5-6 14:42 编辑
比如
加载a.txt
中间为换行符(Tab) 第二列数字是随机的没有规律性1000x只是参考
192.168.1.1 10001
192.168.1.2 10004
192.168.1.3 10002
192.168.1.4 10003
使用批处理转换为
192.168.1.2 10004
192.168.1.4 10003
192.168.1.3 10002
192.168.1.1 10001
然后b.txt输出
作者: zaqmlp 时间: 2019-5-6 13:55
- @echo off
- set info=互助互利,支付宝扫码头像,感谢赞助
- rem 有问题,可加QQ956535081及时沟通
- title %info%
- cd /d "%~dp0"
- set "input=a.txt"
- set "output=b.txt"
- powershell -NoProfile -ExecutionPolicy bypass ^
- $text=[IO.File]::ReadAllText('%input%', [Text.Encoding]::Default).trim().split(\"`r`n\",[StringSplitOptions]::RemoveEmptyEntries);^
- $s=$text^|sort {0+($_.trim() -split '\s+')[1]} -des;^
- [IO.File]::WriteAllLines('%output%', $s, [Text.Encoding]::Default);
- echo;%info%
- pause
复制代码
作者: ushit0001 时间: 2019-5-6 14:42
回复 2# zaqmlp
非常感谢!
作者: cfwyy77_bat 时间: 2019-5-6 14:43
linux的sort 或者坛子里在线第三方库下载的sort就一句话完事。- sort -rn -k2 a.txt >b.txt
复制代码
作者: zaqmlp 时间: 2019-5-6 14:54
回复 3# u**0001
那就赞助下吧
作者: CrLf 时间: 2019-5-7 13:36
如果 tab 可以转空格,那可以这样:- @more /t 16 a.txt | sort /+16 >b.txt
复制代码
如果 b.txt 中要保留空格,就用 for /f 包一层:- @echo off
- (for /f "tokens=1,2" %%a in ('more /t 16 a.txt ^| sort /+16') do echo %%a %%b)>b.txt
复制代码
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |