[請益] 該怎麼分割字串才好 (贈P幣)

作者: FacetheFaith (Yes Man)   2018-12-03 17:48:03
請教一下版上大大們 (若成功解答則贈送P幣200)
有一欄位可能有輸入值如下情況1:
'21481705020021 9 21481705020026 10 21481705020034 11'
其'21481705020021 9', '21481705020026 10', '21481705020034 11'各為一組值
彼此以tab鍵分隔
該欄位也可能有輸入值如下情況2:
'723L04 123L00 131KYW'
其'723L04', '123L00' '131KYW'各為一組值
彼此以空白鍵分隔
倘若以tab鍵來分割情況1的字組,則在遇到情況2的字組就行不通
反之亦然, 倘若以空白鍵來分割情況2的字組,則在遇到情況1的字組就行不通
想請問有沒有一個通用的寫法可以用在以上兩種情況?
作者: flyfoxy (飛狐)   2018-12-03 17:50:00
遇到tab或空白 就切
作者: sowrdking (grow up safe)   2018-12-03 17:51:00
sed -e 's/^[ \t]*//'空白跟tab可以取代成你要的字元就可以囉
作者: sherees (ShaunTheSheep)   2018-12-03 17:52:00
什麼語言啊
作者: t64141 (榕樹)   2018-12-03 18:00:00
看起來問題點是: 空格有時是資料內容,有時是分隔字元?資料有規律嗎?例如5位數的資料用空格當分隔字元,其他情境用tab作為分隔字元; 如果有規律就可以先用tab切,然後判斷各組資料格式是否符合規則,若不符則預設將空格視為分隔符號,反之亦然
作者: dreamnook (亞龍)   2018-12-03 18:08:00
regexp?
作者: v420746k (Tyrone_Huang)   2018-12-03 18:19:00
情況二的字元大小是20。如樓樓上大大說的先用tab切,再對每一個index檢查大小是否為20,是的話就在針對這個index用空格切。
作者: t64141 (榕樹)   2018-12-03 18:27:00
假設有規則,再配合其他大大說的regex來驗證會更簡潔
作者: MOONY135 (談無慾)   2018-12-03 18:43:00
正則?
作者: pttuser2266   2018-12-03 18:53:00
If find tab then .. else ...
作者: justben (BEN)   2018-12-03 18:56:00
str.split(/\s{1,}/)
作者: abc0922001 (中士abc)   2018-12-03 19:13:00
正規化
作者: chocopie (好吃的巧克力派 :))   2018-12-03 19:23:00
我會先判斷分組再處理regex
作者: ripple0129 (perry tsai)   2018-12-03 19:26:00
不就是有tab用tab切,沒tab用空白切嗎,範例太少沒看到難點
作者: alog (A肉哥)   2018-12-03 20:24:00
方法1 先對資料來源做歸類 再根據歸類後的結果用對應的處理方式 策略就是這樣 / 方法 2 將資料的 tab 跟 space 轉換成其中之一 再進行處理 / 方法 3 直接在 regexp 直接下條件包含 tab跟space做切割 只要你的程式有支援但我還是要說 如果你的資料極度重要且變化大 就別傻傻的直接用方法2跟3應該要先釐清完整規律 同時做時就拿資料來驗證把你預期外的早出來找* 不建議直接用一個方式想要省全部
作者: sachung28 (00)   2018-12-03 21:40:00
regex 指定數字重複次數啊 大不了分二次掃檔抓字組
作者: qrtt1 (有些事,有時候。。。)   2018-12-03 21:43:00
生資料的一方,為什麼不能好好地給一種格式就好@@?
作者: Murasaki0110 (麥當勞歡樂送)   2018-12-03 21:44:00
看有沒有tab不就分出來了?
作者: B99303079 (台大建屁孩)   2018-12-03 22:08:00
2
作者: yiefaung (艾克斯卡利伯)   2018-12-03 22:57:00
直接split依元素個數if
作者: giacch   2018-12-04 01:39:00
[\d ]{16,}|\w{6}
作者: exeex (執行檔EX)   2018-12-04 14:51:00
scanf %d
作者: gmoz ( This can't do that. )   2018-12-04 16:16:00
先分類
作者: ron1220 (抓抓)   2018-12-04 19:56:00
先用tab切看能不能切出東西,有切出東西=狀況1;沒有的話=狀況2。狀況1就直接撈值;狀況2的話就再用空白切一次。
作者: Csongs (西歌)   2018-12-04 23:38:00
正規表示法 處理就好了@@
作者: GoGoJoe (gogojoe)   2018-12-07 20:40:00
看white space切出幾個字串,就能分出第幾個case,在將字串組成你要的型式!

Links booklink

Contact Us: admin [ a t ] ucptt.com