标题: [文本处理] 批处理将csv文本内容按某一列排序 [打印本页]
作者: haichuan5121 时间: 2017-2-25 01:40 标题: 批处理将csv文本内容按某一列排序
本帖最后由 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
- @echo off
- if "%~1"==":" (
- for /f "tokens=1,2,* delims= " %%i in (a.csv) do (
- echo;%%j#%%i#%%k
- )
- ) else (
- for /f "tokens=1,2,* delims=#" %%i in (
- 'call "%~f0" :^|sort'
- ) do (
- echo;%%j %%i %%k
- )
- pause & exit /b
- )
复制代码
作者: WHY 时间: 2017-2-26 11:14
- type 1.csv | sort { ($_ -Split ',')[1] }, { ($_ -Split ',')[0] }
复制代码
作者: terse 时间: 2017-2-26 13:04
按什么排序的呢 两位以上数和一位数是不一样的吧
作者: taofan712 时间: 2017-2-27 10:58
回复 2# 回家路上 - @echo off
- for /f "tokens=1-3 delims= " %%a in (a.txt) do (
- echo;%%b %%a %%c
- )>>temp.txt
- for /f "tokens=1-3 delims= " %%i in ('sort temp.txt') do (
- echo;%%j %%i %%k
- )>>b.txt
复制代码
如果是txt可以这样,sort会自动处理第二列的排序。
作者: Nsqs 时间: 2017-2-27 12:23
- @echo off
- for /f "tokens=1-3 delims= " %%1 in (a.txt)do call set #_%%2_%%random%%=%%1 %%2 %%3
- (for /f "tokens=2 delims==" %%1 in ('set #_')do echo %%1)>b.txt
复制代码
如果是按照第二列进行排序
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |