gpt4 book ai didi

regex - 如何在 PostgreSQL 中将包含数值的字符串拆分为三部分?

转载 作者:行者123 更新时间:2023-11-29 11:28:54 26 4
gpt4 key购买 nike

我想使用 regexp_matches() 拆分可能包含数值的给定字符串。它应该标识包含可选符号和可选小数位的数值的第一次出现。不匹配的部分也应返回 - 作为数组的第一个和最后一个位置。

一些示例输入和预期输出值:

'hello+111123.454545world' -> {hello,+111123.454545,world}
'he-lo+111123.454545world' -> {he-lo,+111123.454545,world}
'hel123.5lo+111123.454545world' -> {hel,123.5,lo+111123.454545world}
'hello+111123.454545world' -> {hello,+111123.454545,world}
'hello+111123.454545world' -> {hello,+111123.454545,world}
'1111.15' -> {"",1111.15,""}
'-.234' -> {"",-.234,""}
'hello-.234' -> {hello,-.234,""}

我在处理以下由“TODO”表示的表达式中匹配组的第一部分时遇到问题。它应该匹配任何不能被识别为数值的东西。

select regexp_matches('input', '(TODO)((?:\+|-)?(?:\d*(?:(?:\.)?\d+)))(.*)')

'(TODO)'代表的匹配组需要是第二个匹配组中正则表达式的否定。 (因为需要返回结果)。用于匹配数值的正则表达式工作正常,我需要的是如何匹配字符串的第一部分不是数值。

最佳答案

regexp_matches(input, '(^.*?)([+-]?\d*\.?\d+)(.*$)') AS result_arr
  • 第一个匹配项:(^.*?)
    使用 ^ 锚定到字符串的开头。 non-greedy quantifier *?至关重要。
    它实际上不必是第二个匹配组中正则表达式的否定,因为正则表达式的其余部分是贪婪。所以第一部分是保留的部分,由其余部分定义。

  • 第二场比赛:([+-]?\d*?\.?\d+)
    我稍微简化了你的表达。特别是字符类 [+-] 比非捕获括号 (?:\+|-) 中的两个分支更短更快。
    Non-capturing parentheses是重要的。 (你已经有了。)
    简化了 \d* 来自@maraca 的评论。

  • 第三场比赛:(.*$)
    使用 $ 锚定到字符串的末尾。对于最后一个匹配项,使量词贪婪

SQL Fiddle带有扩展测试用例。

关于regex - 如何在 PostgreSQL 中将包含数值的字符串拆分为三部分?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31632332/

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