来源:在工作过程中,需要统计一些trace信息,也就是一些打点信息,而打点是通过关键字进行的,因此对一个很大的文件进行分析时,想把两个打点之间的内容单独拷贝出来进行分析。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
#!/usr/bin/env python
#__*__ coding: utf-8 __*__
import re
import linecache
def fileparse():
inputfile = input ( 'input sourcfile:' ) ##输入源文件,如a.txt
fp = open (inputfile, 'r' )
number = []
linenumber = 1
keyword = input ( 'slice keyword:' ) ##输入你要切分的关键字
outfilename = input ( 'outfilename:' ) ##输出文件名,如out.txt则写out即可,后续输出的文件是out0.txt,out1.txt...
for eachline in fp:
m = re.search(keyword, eachline) ##查询关键字
if m is not none:
number.append(linenumber) #将关键字的行号记录在number中
linenumber = linenumber + 1
size = int ( len (number))
for i in range ( 0 ,size - 1 ):
start = number[i]
end = number[i + 1 ]
destlines = linecache.getlines(inputfile)[start + 1 :end - 1 ] #将行号为start+1到end-1的文件内容截取出来
fp_w = open (outfilename + str (i) + '.txt' , 'w' ) #将截取出的内容保存在输出文件中
for key in destlines:
fp_w.write(key)
fp_w.close()
if __name__ = = "__main__" :
fileparse()
|
以上这篇python实现根据文件关键字进行切分为多个文件的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/xqn2017/p/8021675.html