gpt4 book ai didi

java - 需要Java正则表达式

转载 作者:行者123 更新时间:2023-12-01 10:33:09 25 4
gpt4 key购买 nike

我需要一个正则表达式,它应该解析带有空格的字符串,如果以引号(单/双)结尾的字符串中存在空格,那么它不应该解析。

abc cde 'efg hij'k lmn'opq rst' 'ijk lmn' u'v'w xyz 'abc' \'\\\\\'  \'_Notes.txt\'

要求O/P:

abc
cde
'efg hij'k
lmn'opq rst'
'ijk lmn'
u'v'w
xyz
'abc'
\'\\\\\'
\'_Notes.txt\'

我使用下面的模式来满足我的要求,但解析如下

Pattern p = Pattern.compile("[^\\s\"']+|\"([^\"]*)\"|'([^']*)'");

操作:

abc
cde
'efg hij' //here k is missing
lmn'opq
rst'
'ijk lmn'
u'v'w
xyz
'abc'
'\\' //here original string is \'\\\\\'
'_Notes.txt' //here origina string \'_Notes.txt\'

最佳答案

看起来您只需要让您的正则表达式找到您描述的一个或多个子模式。所以尝试使用

Pattern p = Pattern.compile("([^\\s\"']+|\"([^\"]*)\"|'([^']*)')+");
// ^---------------------------------^^- add this

DEMO

关于java - 需要Java正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34966345/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com