求Python脚本批量提取大量文件的某一范围行的指定列字符

指定特定范围行的第9个到第12个字符进行输出,不同文件输出的数据保存到相邻的列。比如文件一1444143972340144514407404314461441171048... 指定特定范围行的第9个到第12个字符进行输出,不同文件输出的数据保存到相邻的列。

比如
文件一

14441439 723 40
14451440 740 43
144614411710 48
14471442 706 43
144814432731 49
文件二
14151410 800 43
14171412 824 44
141914142837 46
14201415 816 43
14221417 783 43
指定第三行到第四行的9到12字符输出
结果
1710 2837
706 816
展开
 我来答
albumin
2014-10-30 · TA获得超过1.2万个赞
知道大有可为答主
回答量:4889
采纳率:87%
帮助的人:2411万
展开全部
a=open('a.txt').readlines()
b=open('b.txt').readlines()
alllines=list(zip(a,b))
for no in range(2,4):   #下标从0开始,不包含上标,第三行到第四行为 2-4 ,
    lines=alllines[no]
    line=' '.join(line[8:12] for line in lines)  #9-12个字符为8-12
    print(line)
tim_spac
2014-10-30 · TA获得超过3628个赞
知道大有可为答主
回答量:1804
采纳率:100%
帮助的人:2026万
展开全部
def getelement(filename, linestart, linestop, start, stop):
    with open(filename, 'rt') as handle:
        return [ln[start-1:stop]
                for ln in handle.readlines()[linestart-1:linestop]]

datafiles = ("data1.txt", "data2.txt")
got = [getelement(filename, 3, 4, 9, 12)
       for filename in datafiles]
print "\n".join([" ".join(row) for row in zip(*got)])
追问
文本很多,此处
datafiles = ("data1.txt", "data2.txt")
写成
datafiles = ("data*.txt")
行吗
追答

import glob

def getelement(filename, linestart, linestop, start, stop):
    with open(filename, 'rt') as handle:
        return [ln[start-1:stop]
                for ln in handle.readlines()[linestart-1:linestop]]
 
datafiles = glob.glob("data*.txt")
got = [getelement(filename, 3, 4, 9, 12)
       for filename in datafiles]
print "\n".join([" ".join(row) for row in zip(*got)])
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式