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

[文本处理] 批处理将csv文本内容按某一列排序

[复制链接]
发表于 2017-2-25 01:40:14 | 显示全部楼层 |阅读模式
本帖最后由 pcl_test 于 2017-2-25 13:01 编辑

求一批处理按某一列排序代码;
        要求 先按照B列第一排序 同时再按A列第二排序,

     a.csv    a  2   C              结果B.csv  c  1  6  
                c   1   6                              a   2  c
                b   3   5                              a   3  6
                c   4    8                             b   3   5
               a   3    6                              c   4   8
发表于 2017-2-25 13:24:05 | 显示全部楼层
  1. @echo off
  2. if "%~1"==":" (
  3.         for /f "tokens=1,2,* delims= " %%i in (a.csv) do (
  4.                 echo;%%j#%%i#%%k
  5.         )
  6. ) else (
  7.         for /f "tokens=1,2,* delims=#" %%i in (
  8.                         'call "%~f0" :^|sort'
  9.                 ) do (
  10.                 echo;%%j %%i %%k
  11.         )
  12.         pause & exit /b
  13. )
复制代码

评分

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

查看全部评分

发表于 2017-2-26 11:14:15 | 显示全部楼层
  1. type 1.csv | sort { ($_ -Split ',')[1] }, { ($_ -Split ',')[0] }
复制代码
发表于 2017-2-26 13:04:39 | 显示全部楼层
按什么排序的呢 两位以上数和一位数是不一样的吧
发表于 2017-2-27 10:58:22 | 显示全部楼层
回复 2# 回家路上
  1. @echo off
  2. for /f "tokens=1-3 delims= " %%a in (a.txt) do (
  3. echo;%%b %%a %%c
  4. )>>temp.txt
  5. for /f "tokens=1-3 delims= " %%i in ('sort temp.txt') do (
  6. echo;%%j %%i %%k
  7. )>>b.txt
复制代码
如果是txt可以这样,sort会自动处理第二列的排序。
发表于 2017-2-27 12:23:01 | 显示全部楼层
  1. @echo off
  2. for /f "tokens=1-3 delims= " %%1 in (a.txt)do call set #_%%2_%%random%%=%%1 %%2 %%3
  3. (for /f "tokens=2 delims==" %%1 in ('set #_')do echo %%1)>b.txt
复制代码
如果是按照第二列进行排序
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 13:50 , Processed in 0.020732 second(s), 12 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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