Re: [問題] 關於排序
※ 引述《LiloHuang (四年前兩年後)》之銘言:
: 我講重點就好
: @data = map { substr $_ ,3 }
: sort
: map { [split " "]->[1].$_ } @data;
: 其實寫法等同於
: @data = map { [split " "]->[1].$_ } @data;
: @data = sort @data;
: @data = map { substr $_ , 3 } @data;
: 當執行第一列程式碼時 我故意把NO* 這個欄位擺到前面來
: split " " 是切割原本每一個列的字串 ( Row跟Column常常會被誤用 )
: "A NO1 2006/10/10 18:36" 變成一個匿名陣列
: ["A","NO1","2006/10/10 18:36"] 然後取出陣列1的資料NO*
: 尾巴還得加上原始的資料,其實有其他作法,例如加上原始的陣列位置
: 不擺原始資料,我說過,寫法可以有很多種^^ 這邊我只舉這個範例
: 其目的是在於經過排序過程,原始資料會跟著一起動,不管是GRT或者
: Schwartzian轉換的精神是在於這邊(Schwartzian轉換通常以匿名陣列加在前面)
: 經過map資料會變成
: NO1A NO1 2006/10/10 18:36
: NO2B NO2 2007/12/12 16:37
: NO3C NO3 2007/12/13 17:40
: NO1D NO1 2005/01/01 00:01
: NO2G NO2 2007/12/13 17:20
: 特別注意一點,這邊的NO*欄位長度都是固定的,如果不固定要自己padding
: 例如使用pack來padding
: 當執行第二列程式碼時,資料會進行排序
: NO1A NO1 2006/10/10 18:36
: NO1D NO1 2005/01/01 00:01
: NO2B NO2 2007/12/12 16:37
: NO2G NO2 2007/12/13 17:20
: NO3C NO3 2007/12/13 17:40
: 當執行第三列程式碼時,目的就是把前面的NO*給刪除,因此使用substr
: A NO1 2006/10/10 18:36
: D NO1 2005/01/01 00:01
: B NO2 2007/12/12 16:37
: G NO2 2007/12/13 17:20
: C NO3 2007/12/13 17:40
應L大要求~我把一部份範例貼上
WIP0509.csv C2 Depo. P63122800A 2006/11/9 18:32:19
WIP0509.csv C2 Depo. E62625700A 2007/1/11 10:38:59
WIP0509.csv Spacer SiN CVD E6071151PA 2006/7/9 04:31:31
WIP0509.csv Spacer SiN CVD E60711533A 2006/7/9 04:31:31
WIP0509.csv IN-Gate-Stack-Depo E7061360CA 2007/3/10 13:59:17
WIP0509.csv IN-Gate-Stack-Depo E7061370MA 2007/3/13 04:10:24
WIP0510.csv WAT E70221826A 2007/4/27 22:13:11
WIP0511.csv DT Photo E70222107A 2007/3/6 21:04:42
WIP0511.csv DT Photo E70222100A 2007/3/6 21:04:42
WIP0511.csv
WIP0511.csv BS Poly CVD E6101390PA 2006/5/25 18:49:25
WIP0511.csv BS Poly CVD E6190810DA 2006/9/25 03:31:02
WIP0511.csv BS Poly CVD E63428406A 2006/9/25 12:10:04
WIP0511.csv
最前面的是檔名,再來是name,然後是我想排序的NO
這是我已經從約30個檔案整理出來的東西
因為name的格式大多不固定,空格都不固定
所以想要從試著後面切回來
我有用L大的程式測試過,發現他也會把name一起作排列
有相同NO部分還是會被拆開這樣
中間有檔名後面沒接東西的
輸出就會把檔名都跑在前面@@
有試過在一開始要把空格chop掉
但都沒成功
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 61.65.55.161
※ 編輯: handsomegirl 來自: 61.65.55.161 (07/20 11:26)
討論串 (同標題文章)
Perl 近期熱門文章
PTT數位生活區 即時熱門文章