【问题标题】:Python regex extract lines between substrings that start with certain criteriaPython regex 提取以特定条件开头的子字符串之间的行
【发布时间】:2021-06-25 20:18:15
【问题描述】:

我已对此进行了编辑,使其更加清晰并提供了解决方案。

我想使用正则表达式在子字符串中搜索以字符 -- 开头的文本,并提取该行之后的所有文本。我已经成功地将这两个部分单独工作(1. 子字符串搜索和 2. -- 搜索),我只是不确定如何有效地组合它们。我有一个字符串 -

qry = ''' 
with 
qry_1 as ( -- some text
   SELECT ID, 
          NAME
   FROM   ( ... other code...
),
qry_2 as ( 
    SELECT coalesce (table1.ID, table2.ID) as ID,
           NAME
   FROM (...other code...
),
qry_3 as (
-- some text
     SELECT id.WEATHER AS WEATHER_MORN,
            ROW_NUMBER() OVER(PARTITION BY id.SUN
                ORDER BY id.TIME) AS SUN_TIME,
            id.RAIN,
            id.MIST
   FROM (...other code..
-- some other text
)
'''
  1. 我可以在这里通过re.findall 提取子查询信息 -
sub = re.findall('\),\s{2,}(.*?)as\s\(',qry)
  1. 以及特殊字符搜索
re.findall(r'--+(.*)(.\s)',qry)
  1. 最终用于在字符串之间搜索评论。

但是如何成功地合并第 3 步呢?

在这里感谢您的指导

【问题讨论】:

  • 我会从逐行处理字符串开始。

标签: python regex string findall


【解决方案1】:

步骤 3 成功运行

commentary = [re.findall(r'--+(.*)(.\s)', i) 
     for i in re.findall('\),\s{2,}(.*?)as\s\(',qry,flags=re.S)]

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-03-06
    • 2020-05-11
    • 2019-10-13
    • 2023-03-21
    • 1970-01-01
    • 2015-06-24
    • 1970-01-01
    相关资源
    最近更新 更多