| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1594 人关注过本帖
标题:关于正则表达式匹配问题
只看楼主 加入收藏
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
帖 子:94
专家分: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
快速回复:关于正则表达式匹配问题
数据加载中...
 
   



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

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