Soft_Job 板


LINE

請教一下版上大大們 (若成功解答則贈送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的字組就行不通 想請問有沒有一個通用的寫法可以用在以上兩種情況? --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.170.193.241
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Soft_Job/M.1543830485.A.F52.html
1F:推 flyfoxy: 遇到tab或空白 就切 12/03 17:50
2F:→ sowrdking: sed -e 's/^[ \t]*//' 12/03 17:51
3F:→ sowrdking: 空白跟tab可以取代成你要的字元就可以囉 12/03 17:51
4F:推 sherees: 什麼語言啊 12/03 17:52
5F:推 t64141: 看起來問題點是: 空格有時是資料內容,有時是分隔字元? 12/03 18:00
6F:→ t64141: 資料有規律嗎?例如5位數的資料用空格當分隔字元,其他情 12/03 18:05
7F:→ t64141: 境用tab作為分隔字元; 如果有規律就可以先用tab切,然後判 12/03 18:05
8F:→ t64141: 斷各組資料格式是否符合規則,若不符則預設將空格視為分隔 12/03 18:05
9F:→ t64141: 符號,反之亦然 12/03 18:05
10F:→ dreamnook: regexp? 12/03 18:08
11F:→ v420746k: 情況二的字元大小是20。如樓樓上大大說的先用tab切,再 12/03 18:19
12F:→ v420746k: 對每一個index檢查大小是否為20,是的話就在針對這個ind 12/03 18:19
13F:→ v420746k: ex用空格切。 12/03 18:19
14F:→ t64141: 假設有規則,再配合其他大大說的regex來驗證會更簡潔 12/03 18:27
15F:→ MOONY135: 正則? 12/03 18:43
16F:→ pttuser2266: If find tab then .. else ... 12/03 18:53
17F:推 justben: str.split(/\s{1,}/) 12/03 18:56
18F:推 abc0922001: 正規化 12/03 19:13
19F:推 chocopie: 我會先判斷分組再處理regex 12/03 19:23
20F:推 ripple0129: 不就是有tab用tab切,沒tab用空白切嗎,範例太少沒看 12/03 19:26
21F:→ ripple0129: 到難點 12/03 19:26
22F:→ alog: 方法1 先對資料來源做歸類 再根據歸類後的結果用對應的處理 12/03 20:24
23F:→ alog: 方式 策略就是這樣 / 方法 2 將資料的 tab 跟 space 轉換成 12/03 20:24
24F:→ alog: 其中之一 再進行處理 / 方法 3 直接在 regexp 直接下條件包 12/03 20:24
25F:→ alog: 含 tab跟space做切割 只要你的程式有支援 12/03 20:24
26F:→ alog: 但我還是要說 如果你的資料極度重要且變化大 就別傻傻的直 12/03 20:25
27F:→ alog: 接用方法2跟3 12/03 20:25
28F:→ alog: 應該要先釐清完整規律 同時做時就拿資料來驗證把你預期外的 12/03 20:26
29F:→ alog: 早出來 12/03 20:26
30F:→ alog: 找* 不建議直接用一個方式想要省全部 12/03 20:27
31F:→ sachung28: regex 指定數字重複次數啊 大不了分二次掃檔抓字組 12/03 21:40
32F:→ qrtt1: 生資料的一方,為什麼不能好好地給一種格式就好@@? 12/03 21:43
33F:→ Murasaki0110: 看有沒有tab不就分出來了? 12/03 21:44
34F:噓 B99303079: 2 12/03 22:08
35F:推 yiefaung: 直接split依元素個數if 12/03 22:57
36F:推 giacch: [\d ]{16,}|\w{6} 12/04 01:39
37F:推 exeex: scanf %d 12/04 14:51
38F:推 gmoz: 先分類 12/04 16:16
39F:→ ron1220: 先用tab切看能不能切出東西,有切出東西=狀況1;沒有的 12/04 19:56
40F:→ ron1220: 話=狀況2。狀況1就直接撈值;狀況2的話就再用空白切一次 12/04 19:56
41F:→ ron1220: 。 12/04 19:56
42F:推 Csongs: 正規表示法 處理就好了@@ 12/04 23:38
43F:推 GoGoJoe: 看white space切出幾個字串,就能分出第幾個case,在將字 12/07 20:40
44F:→ GoGoJoe: 串組成你要的型式! 12/07 20:40







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:iOS站內搜尋

TOP