小編給大家分享一下使用python實(shí)現(xiàn)根據(jù)指定字符截取對(duì)應(yīng)的行,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)公司專注于企業(yè)全網(wǎng)營(yíng)銷推廣、網(wǎng)站重做改版、黃島網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5場(chǎng)景定制、商城網(wǎng)站定制開(kāi)發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為黃島等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。工作中遇到的,在一個(gè).c文件中有很多函數(shù),這個(gè).c是自動(dòng)生成的,需要將所有的函數(shù)通過(guò)extern放到.h中,每個(gè)函數(shù)都是UINT32 O_開(kāi)頭,通過(guò)正則表達(dá)式進(jìn)行字符匹配以及通過(guò)linecache來(lái)截取特定行。
代碼如下:
#! /usr/bin/env python # encoding:utf-8 # ! /usr/bin/env python # encoding:utf-8 import re import linecache file = 'D:\PUSCH_job3.txt' outfile = 'D:\outfile3.txt' lineNumber = 1 with open(file,'r') as f: number = [] for line in f.readlines(): m = re.findall(r"UINT32 O_\w+",line) #匹配含有字符'UINT32 O_'的行 if m: number.append(lineNumber) n = re.findall(r"OUT \w+",line) #假設(shè)只有一個(gè)OUT if n: number.append(lineNumber) lineNumber += 1 with open(outfile, 'w+') as f_w: for j in range(len(number)): if j%2 == 0: start = number[j] end = number[j+1] destlines = linecache.getlines(file)[start-1:end] #截取start-end行的字符,不包括start-1,但包含end行 f_w.write('extern ') for i in range(len(destlines)): if i != len(destlines)-1: f_w.write(destlines[i]) else: f_w.write(destlines[i].replace('\n',';\n')) f_w.write('\n')
輸入:
UINT32 O_FUNC1(UINT32 uwA, IN UINT32 uwB, IN UINT32* puwC, IN UINT32* puwD, OUT UINT32* puwE) { // }
輸出:
extern UINT32 O_FUNC1(UINT32 uwA, IN UINT32 uwB, IN UINT32* puwC, IN UINT32* puwD, OUT UINT32* puwE);
以上是“使用python實(shí)現(xiàn)根據(jù)指定字符截取對(duì)應(yīng)的行”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!