我正在尝试在文件列表中找到以下标题并将其替换为我自己的。
/*************************************************************************************
* Company: XXX
* File Name: myfile1.c
* Author: MyName
* Date: 30/12/2011
* Operating Environment: XXX
* Compiler with Version Number:
* Description: This file contains an array which returns a structure having API characteristics.
* Version:
***********************************************************************************/
基本上我正在尝试编写一个python程序来遍历目录列表并在所有文件中进行字符串替换。以下是我的程序的代码:
import sys
import os
import re
correctlicheader = r'''
/* <MY-HEADER>
*
*/
'''
def changelic():
startdir = sys.argv[1]
for root, dirs, files in os.walk(startdir):
for file in files:
actualfilename = os.path.join(root, file)
print("Reading file: %s" %(actualfilename))
f = open(actualfilename, 'r')
read_data = f.read()
#try replacing the incorrect header
p = re.compile("<MY-REGULAREXPRESSION-HERE>")
changed_data = p.sub(correctlicheader, read_data, 1)
f.close()
f= open(actualfilename, 'w')
f.write(changed_data)
f.close()
print("End")
if __name__ == '__main__':
changelic()
问题是没有得到 ' MY-REGULAREEXPRESSION-HERE ' 的权利。我试过
p = re.compile("/\*[\*]*\r\n[ *[a-zA-Z0-9:/\.]+\r\n]*\*/")
以及上述的各种排列。但我不断得到
matched = p.match(read_data)
None
有什么建议可以替换“MY-REGULAREXPRESSION-HERE”吗?另外,如果没有 open(read-mode)-close-open(write-mode)-write ,有没有更好的方法来做同样的事情?