国产成人AV无码一二三区,少女1到100集,国产精品久久久久精品综合紧,巜公妇之诱感肉欲HD在线播放

文章 > Python常见问题 > Python怎么从sql提取表名

Python怎么从sql提取表名

头像

月亮邮递员

2020-03-25 16:40:064664浏览 · 0收藏 · 0评论

本篇文章介绍了Python使用ply和re模块提取sql语句中表名的方法,具有一定的参考价值,希望对各位学习Python的朋友有帮助!

Python怎么从sql提取表名

ply:词法语法解析模块;

re:正则表达式模块。

全部代码如下:

import ply.lex as lex, re


def extract_table_name_from_sql(sql_str):

    # remove the /* */ comments
    q = re.sub(r"/\*[^*]*\*+(?:[^*/][^*]*\*+)*/", "", sql_str)

    # remove whole line -- and # comments
    lines = [line for line in q.splitlines() if not re.match("^\s*(--|#)", line)]

    # remove trailing -- and # comments
    q = " ".join([re.split("--|#", line)[0] for line in lines])

    # split on blanks, parens and semicolons
    tokens = re.split(r"[\s)(;]+", q)

    # scan the tokens. if we see a FROM or JOIN, we set the get_next
    # flag, and grab the next one (unless it's SELECT).

    result = []
    get_next = False
    for token in tokens:
        if get_next:
            if token.lower() not in ["", "select"]:
                result.append(token)
            get_next = False
        get_next = token.lower() in ["from", "join"]

    return result

sql2="SELECT a.time_updated_server/1000,content,nick,name FROM      " \
     "table1 a JOIN   " \
     "table2 b ON a.sender_id = b.user_id JOIN table3 c ON a.channel_id = c.channel_id JOIN table4 d ON c.store_id = d.store_id WHERE sender_id NOT IN(SELECT user_id FROM table5 WHERE store_id IN ('agent_store:1', 'ask:1')) AND to_timestamp(a.time_updated_server/1000)::date >= '2014-05-01' GROUP BY 1,2,3,4 HAVING sum(1) > 500 ORDER BY 1 ASC"
print(extract_table_name_from_sql(sql2))

更多技术请关注Python视频教程

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

国产在线观看免费全集电视剧网站 | 榜上佳婿电视剧全集免费观看高清| 千人千色T9T9T9T9T9| 《医务室上垒》动漫全集在线观看 | 中美芬太尼是咋回事| 每日大赛吃瓜爆料每日大赛聚集地| 密爱在线观看| 暴躁少女零九CSGO| 15岁初中生用袜子套几几| 邻里大战| 翔田千里| 美国大片又大又好看的PPT| 适合做前看的短篇小说| 强伦轩女教师在线播放| 麻花星空影视在线看电视免费版| 秘书奶头好大下面好紧| 宝贝别忍着喷出来嗯啊哦漫画| 双男主高干文小说| 男人碰到紧的会念念不忘吗?| 老公在洗澡我被公干日本| 怀孕期间叫闺蜜来给老公消火| 年轻的老师| 扒开腿挺进肉蒂抽搐喷潮BL| 老婆同意了交换男人心态| 乖再分开点小说免费阅读| 成品人和精品人的区别在哪里知乎| CSGO网站开箱推荐| 女子SPA高潮呻吟抽搐| 少女与船夫1977经典版歌曲| 《伦敦空姐美版2023》| 马配人的视频在线观看| 燕子课文| 公交车NP粗暴H强J玩弄| 爱痴癫| 姨母的绣感中字完整版| 小雪被老汉玩得嗷嗷叫| 电影《法国空姐2》| 胡乱的深见君| 九九在线观看免费播放大全电视剧 | 无码| 人与动物免费观看电视剧完整版