我正在尝试解析搜索词。搜索词是一个长字符串,例如:
label:none author:@root label:~"To+Do" label:~'"test me"' label:~"No Label" label:~'won"t fix' this is a search term
我正在尝试将其解析为单独的键值对:
[{label: "none"}, {author:"@root"}, {label:"~\"To+Do\""}, {label: "~"test me\""}, {label: "~\"No Label\""}, {label: "~won\"t fix"}, {search: "this is a search term"}]
搜索词是最后一个没有键的项目。如果搜索词有空格,则会用引号引起来。
我开始通过这样做来解析它:
(label:.*?|author:.*?|milestone:.*?)
我不确定这是否有效,但我也对如何获取最后一个搜索词感到困惑。甚至不确定这是否可能。
最大的问题是引用的东西,我不知道如何匹配引用的东西。最后我想做的是用空格分割字符串,同时忽略空格周围的引号。
我使用@
作为作者,~
作为标签,%
作为里程碑。
最佳答案
这似乎有效...我还将输出结构转换为更易于使用的结构:
term = `label:none author:@root label:~"To+Do" label:~'"test me"' label:~"No Label" label:~'won"t fix' this is a search term`
re = /(\w+):([~%@]?)(?:"(.*?)"|'(.*?)'|(\S+))/g;
opts = [];
term = term.replace(re, function (_, prop, operator, v1, v2, v3) {
opts.push({prop, operator, value: v1 || v2 || v3});
return '';
});
opts.push({search: term.trim()});
console.log(opts);
关于javascript - 如何匹配引号内的搜索词,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41126586/