首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从两个不同的文件中读取行,如果找到匹配的,则打印行号[编辑]

从两个不同的文件中读取行,如果找到匹配的,则打印行号。

这个问题可以通过编写一个脚本来解决。下面是一个示例的Python脚本:

代码语言:txt
复制
def find_matching_lines(file1, file2):
    lines1 = set()
    matching_lines = []

    # 读取文件1的所有行并存储到集合中
    with open(file1, 'r') as f1:
        for line in f1:
            lines1.add(line.strip())

    # 逐行读取文件2,并检查是否在文件1中存在匹配的行
    with open(file2, 'r') as f2:
        for line_number, line in enumerate(f2, start=1):
            if line.strip() in lines1:
                matching_lines.append(line_number)

    return matching_lines

file1 = 'file1.txt'
file2 = 'file2.txt'
matching_lines = find_matching_lines(file1, file2)

if matching_lines:
    print("匹配的行号:")
    for line_number in matching_lines:
        print(line_number)
else:
    print("未找到匹配的行。")

这个脚本首先会读取文件1的所有行,并将其存储到一个集合中。然后,它会逐行读取文件2,并检查每一行是否在文件1的集合中存在匹配。如果找到匹配的行,则会将其行号存储到一个列表中。最后,脚本会打印出匹配的行号。

这个脚本可以适用于任何文本文件,并且可以根据实际需求进行修改和扩展。

请注意,以上示例中没有提及具体的云计算品牌商和产品,因为根据提问要求,不能提及亚马逊AWS、Azure、阿里云、华为云、天翼云、GoDaddy、Namecheap、Google等流行的云计算品牌商。如果需要使用云计算服务来处理文件,可以参考腾讯云的对象存储(COS)服务,该服务提供了存储和管理大规模数据的能力,可以方便地进行文件的读取和处理。具体的产品介绍和链接地址可以参考腾讯云的官方文档:腾讯云对象存储(COS)

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

python 文件内容对比操作

#-*-coding:utf-8-*- import re f1 = open('d:/test/mail/bounce_list.txt','r') f2 = open('d:/test/mail/828-820.txt', 'r') ff = open('d:/test/mail/ok1', 'w') f3 = open('d:/test/mail/ok-sort', 'w') f4 = open('d:/test/mail/ok-ok', 'w') # 排除文件从f2里面踢除包含f1里的文件 file1 = [line for line in f1] file1.sort() file2 = [line for line in f2] file2.sort() for i in file2:     if i not in file1:         print i         ff.write(i) ff.close() # 过滤重复的内容 fff = open('d:/test/mail/ok1', 'r') lines_seen = set() for line in fff:     if line not in lines_seen:         f3.write(line)         lines_seen.add(line) f3.close() # 过滤关键字的内容 pat = '@oauth.*.com$' f33 = open('d:/test/mail/ok-sort', 'r') for line in f33:     if not re.findall(pat, line):         print line         f4.write(line)        f4.close()

03

Linux之文件管理及文本处理

文件管理不外乎文件或目录的创建、删除、查询、移动,有mkdir/rm/mv 文件查询是重点,用find来进行查询;find的参数丰富,也非常强大; 有时候,需要给文件创建一个别名,我们需要用到ln,使用这个别名和使用原文件是相同的效果; 2.1. 创建和删除 创建:mkdir 删除:rm 删除非空目录:rm -rf file目录 删除日志 rm *log (等价: $find ./ -name “*log” -exec rm {} ;) 移动:mv 复制:cp (复制目录:cp -r ) 查看当前目录下文件个数: $find ./ | wc -l 复制目录: $cp -r source_dir dest_dir 2.2. 目录切换 找到文件/目录位置:cd 切换到上一个工作目录: cd - 切换到home目录: cd or cd ~ 显示当前路径: pwd 更改当前工作路径为path: $cd path 2.3. 列出目录项 显示当前目录下的文件 ls 按时间排序,以列表的方式显示目录项 ls -lrt 以上这个命令用到的频率如此之高,以至于我们需要为它建立一个快捷命令方式: 在.bashrc 中设置命令别名: alias lsl='ls -lrt' alias lm='ls -al|more' 这样,使用lsl,就可以显示目录中的文件按照修改时间排序;以列表方式显示; 给每项文件前面增加一个id编号(看上去更加整洁): >ls | cat -n 1 a 2 a.out 3 app 4 b 5 bin 6 config 注:.bashrc 在/home/你的用户名/ 文件夹下,以隐藏文件的方式存储;可使用 ls -a 查看; 2.4. 查找目录及文件 find/locate 搜寻文件或目录: $find ./ -name "core*" | xargs file 查找目标文件夹中是否有obj文件: $find ./ -name '*.o' 递归当前目录及子目录删除所有.o文件: $find ./ -name "*.o" -exec rm {} \; find是实时查找,如果需要更快的查询,可试试locate;locate会为文件系统建立索引数据库,如果有文件更新,需要定期执行更新命令来更新索引库: $locate string 寻找包含有string的路径: $updatedb 与find不同,locate并不是实时查找。你需要更新数据库,以获得最新的文件索引信息。 2.5. 查看文件内容 查看文件:cat vi head tail more 显示时同时显示行号: $cat -n 按页显示列表内容: $ls -al | more 只看前10行: $head - 10 ** 显示文件第一行: $head -1 filename 显示文件倒数第五行: $tail -5 filename 查看两个文件间的差别: $diff file1 file2 动态显示文本最新信息: $tail -f crawler.log 2.6. 查找文件内容 使用egrep查询文件内容: egrep '03.1\/CO\/AE' TSF_STAT_111130.log.012 egrep 'A_LMCA777:C' TSF_STAT_111130.log.035 > co.out2 2.7. 文件与目录权限修改 改变文件的拥有者 chown 改变文件读、写、执行等属性 chmod 递归子目录修改: chown -R tuxapp source/ 增加脚本可执行权限: chmod a+x myscript 2.8. 给文件增加别名 创建符号链接/硬链接: ln cc ccAgain :硬连接;删除一个,将仍能找到; ln -s cc ccTo :符号链接(软链接);删除源,另一个无法使用;(后面一个ccTo 为新建的文件) 2.9. 管道和重定向 批处理命令连接执行,使用 | 串联: 使用分号 ; 前面成功,则执行后面一条,否则,不执行:&& 前面失败,则后一条执行: || ls /proc && echo suss! || echo failed. 能够提示命名是否执行成功or失败; 与上述相同效果的是: if ls /proc; then echo suss; else echo fail; fi 重定向: ls proc/*.c > list 2> &l 将标准输出和标准错误重定向

02
领券