【精】用python找出多个SQL文件中用到的表

该代码示例展示了一种方法,通过Python遍历指定文件夹中的所有SQL文件,然后使用正则表达式匹配以WMDP_ETL_ODS开头的表名。程序首先定义了匹配规则,接着获取文件夹路径下的所有文件,对每个文件读取内容并找到匹配的表名,最后打印出这些表名及其所在的源文件。
摘要由CSDN通过智能技术生成

需求是找出文件夹里多个SQL文件里用到的所有ods开头的表有哪些
思路是先遍历每个文件,然后再用正则来匹配
代码如下:

import os
import re

# sql_regax = re.compile("WMDP_ETL_ODS.\w+|WMDP_ETL_DW.\w+",re.IGNORECASE)  #需要匹配的表前缀,忽略大小写,多个条件用|分割
sql_regax = re.compile("WMDP_ETL_ODS.\w+",re.IGNORECASE)
path = 'D://Users//User//Desktop//DW' #文件夹目录

def getCurrentFile(rootDir, allFiles=[]):
    list = os.listdir(rootDir)  # 列出文件夹下所有的目录与文件
    for i in range(0, len(list)):
        path = os.path.join(rootDir, list[i])
        allFiles.append(path)
    return allFiles
# print("获取当前目录信息:")
currentFileList = getCurrentFile(path)
myfilelist=[]
for i in currentFileList:
    file = i.split('\\')[1]  #获取文件名
    myfilelist.append(file)
# print(myfilelist)

for f in myfilelist:
    # print(f)
    # if f=='CS_BARCODE_SCAN_EVT_INC.sql':
        filetxt = os.path.join(path,f)
        all_the_text =open(filetxt,encoding='utf-8').read( )
        res_list = sql_regax.findall(all_the_text)
        if res_list!=None:
            for res in res_list:
                print(res+',sourece:'+f)


运行结果:
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值