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

[文本处理] [已解决]请问如何使用批处理把文本中第二列的数字按数字大小来排序?

[复制链接]
发表于 2019-5-6 10:54:23 | 显示全部楼层 |阅读模式
本帖最后由 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输出

评分

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

查看全部评分

发表于 2019-5-6 13:55:13 | 显示全部楼层
  1. @echo off
  2. set info=互助互利,支付宝扫码头像,感谢赞助
  3. rem 有问题,可加QQ956535081及时沟通
  4. title %info%
  5. cd /d "%~dp0"
  6. set "input=a.txt"
  7. set "output=b.txt"
  8. powershell -NoProfile -ExecutionPolicy bypass ^
  9.     $text=[IO.File]::ReadAllText('%input%', [Text.Encoding]::Default).trim().split("`r`n",[StringSplitOptions]::RemoveEmptyEntries);^
  10.     $s=$text^|sort {0+($_.trim() -split '\s+')[1]} -des;^
  11.     [IO.File]::WriteAllLines('%output%', $s, [Text.Encoding]::Default);
  12. echo;%info%
  13. pause
复制代码

评分

参与人数 1技术 +1 收起 理由
ushit0001 + 1 乐于助人

查看全部评分

 楼主| 发表于 2019-5-6 14:42:28 | 显示全部楼层
回复 2# zaqmlp

非常感谢!
发表于 2019-5-6 14:43:59 | 显示全部楼层
linux的sort  或者坛子里在线第三方库下载的sort就一句话完事。
  1. sort -rn -k2 a.txt >b.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
ushit0001 + 1 乐于助人

查看全部评分

发表于 2019-5-6 14:54:07 | 显示全部楼层
回复 3# u**0001

那就赞助下吧
发表于 2019-5-7 13:36:59 | 显示全部楼层
如果 tab 可以转空格,那可以这样:
  1. @more /t 16 a.txt | sort /+16 >b.txt
复制代码
如果 b.txt 中要保留空格,就用 for /f 包一层:
  1. @echo off
  2. (for /f "tokens=1,2" %%a in ('more /t 16 a.txt ^| sort /+16') do echo %%a        %%b)>b.txt
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 05:26 , Processed in 0.020656 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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