标题:关于正则表达式匹配问题
只看楼主
zhwlyfx
Rank: 2
等 级:论坛游民
帖 子:6
专家分:34
注 册:2009-12-31
结帖率:0
 问题点数:0 回复次数:2 
关于正则表达式匹配问题
程序代码:
# -*- coding:utf-8 -*-
from re import search,sub
import os
zt_array=[]
file_path="d:\\fczys"
sql="""--acc_books
insert into acc_books(id,name,db_pref,flag,type,text1,text2,text3,text4,text5,flag1,flag2,flag3,flag4,flag5,remark,data_type,book_year,book_code,area_code,split_str,storage_location,date_stamp,set_year)

 values(2690,'总预算账','3799_01',1,1,'','-1','','','',0,0,-1,-1,-1,'','','2016','371325001_01','371325001','4,2,2,2,2,2,2,2,2,2,2,2,2,2','',to_date('2015-09-24', 'dd-mm-yyyy hh24:mi:ss'),'');
     """
string=sub("([.\n]*values\()(.*)(\);)",r"\2",sql)
print(string)

我想要的结果是:
2690,'总预算账','3799_01',1,1,'','-1','','','',0,0,-1,-1,-1,'','','2016','371325001_01','371325001','4,2,2,2,2,2,2,2,2,2,2,2,2,2','',to_date('2015-09-24', 'dd-mm-yyyy hh24:mi:ss'),''
就是values后面括号里面的内容,但是运行结果却是:
--acc_books
insert into acc_books(id,name,db_pref,flag,type,text1,text2,text3,text4,text5,flag1,flag2,flag3,flag4,flag5,remark,data_type,book_year,book_code,area_code,split_str,storage_location,date_stamp,set_year)
 2690,'总预算账','3799_01',1,1,'','-1','','','',0,0,-1,-1,-1,'','','2016','371325001_01','371325001','4,2,2,2,2,2,2,2,2,2,2,2,2,2','',to_date('2015-09-24', 'dd-mm-yyyy hh24:mi:ss'),''

也就是说上面的那个匹配替换只是把values和括号替换了,但是values前面的值都没有被替换
搜索更多相关主题的帖子: 替换 values 匹配 正则表达式 to_date 
2020-01-03 23:08
时光流逝
Rank: 4
来 自:北京
等 级:业余侠客
威 望:8
帖 子:92
专家分:297
注 册:2019-11-16
得分:0 
我表示我不懂正则表达式
2020-02-23 19:08
phiplato
Rank: 2
等 级:新手上路
威 望:3
帖 子:22
专家分:7
注 册:2020-4-24
得分:0 
search("(?m)[\s\S]*?values\(([\s\S]*?)\);[\s\S]*?",sql).group(1)

[此贴子已经被作者于2020-4-24 21:44编辑过]

2020-04-24 21:42



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-498799-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.132622 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved