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

[文本处理] 批处理如何取一列数据的最大值?

[复制链接]
发表于 2013-8-23 14:28:49 | 显示全部楼层 |阅读模式
本帖最后由 pcl_test 于 2016-7-21 18:59 编辑

源数据如下:
a11        4
a14        5
a13        6
a10        7
b01        1
b04        2
b07        3
b08        4
c08        6
c11        7
c12        8
c05        9
比较第二列,如何取得a 、b、c的最大值,结果如下:
a10        7
b08        4
c05        9
发表于 2013-8-23 15:02:45 | 显示全部楼层
本帖最后由 terse 于 2013-8-23 16:20 编辑

最好一次讲清要求   有序号的话 这样行不
  1. @echo off
  2. %1(for /f "tokens=1,2*" %%a in ('%~s0 : ^| sort /r') do if not defined %%a set %%a=a&echo %%c %%b)&pause & exit
  3. for /f "tokens=1*" %%a in (A.txt) do (
  4.         for /f "delims=0123456789" %%c in ("%%a") do (
  5.                  echo %%c %%b  %%a
  6.         )
  7. )
复制代码
发表于 2013-8-23 15:19:53 | 显示全部楼层
GNU sort + gawk
  1. sort -k2,2nr a.txt | gawk "!a[$1]++"
复制代码
 楼主| 发表于 2013-8-23 15:56:14 | 显示全部楼层
回复 3# Batcher
执行的时候出现 “输入文件指定了两次”。错误,刚才改了下,a b c 后面还有序号
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-21 14:57 , Processed in 0.030709 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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