请教一下版上大大们 (若成功解答则赠送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:00sed -e 's/^[ \t]*//'空白跟tab可以取代成你要的字符就可以囉
作者:
sherees (ShaunTheSheep)
2018-12-03 17:52:00什么语言啊
作者: t64141 (榕树) 2018-12-03 18:00:00
看起来问题点是: 空格有时是资料内容,有时是分隔字符?资料有规律吗?例如5位数的资料用空格当分隔字符,其他情境用tab作为分隔字符; 如果有规律就可以先用tab切,然后判断各组资料格式是否符合规则,若不符则默认将空格视为分隔符号,反之亦然
作者: v420746k (Tyrone_Huang) 2018-12-03 18:19:00
情况二的字符大小是20。如楼楼上大大说的先用tab切,再对每一个index检查大小是否为20,是的话就在针对这个index用空格切。
作者: t64141 (榕树) 2018-12-03 18:27:00
假设有规则,再配合其他大大说的regex来验证会更简洁
作者: pttuser2266 2018-12-03 18:53:00
If find tab then .. else ...
作者:
justben (BEN)
2018-12-03 18:56:00str.split(/\s{1,}/)
作者:
chocopie (好吃的巧克力派 :))
2018-12-03 19:23:00我会先判断分组再处理regex
不就是有tab用tab切,没tab用空白切吗,范例太少没看到难点
作者:
alog (A肉哥)
2018-12-03 20:24:00方法1 先对资料来源做归类 再根据归类后的结果用对应的处理方式 策略就是这样 / 方法 2 将资料的 tab 跟 space 转换成其中之一 再进行处理 / 方法 3 直接在 regexp 直接下条件包含 tab跟space做切割 只要你的程式有支援但我还是要说 如果你的资料极度重要且变化大 就别傻傻的直接用方法2跟3应该要先厘清完整规律 同时做时就拿资料来验证把你预期外的早出来找* 不建议直接用一个方式想要省全部
regex 指定数字重复次数啊 大不了分二次扫档抓字组
作者:
qrtt1 (有些事,有时候。。。)
2018-12-03 21:43:00生资料的一方,为什么不能好好地给一种格式就好@@?
作者:
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:00scanf %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,在将字串组成你要的型式!