美文网首页
第二十九课:文件:一个任务

第二十九课:文件:一个任务

作者: 无罪的坏人 | 来源:发表于2018-08-03 00:39 被阅读0次

    内容来源于网络,本人只是在此稍作整理,如有涉及版权问题,归小甲鱼官方所有。

    练习题(来自小甲鱼官方论坛)

    编程题

    0. 编写一个程序,接受用户的输入并保存为新的文件,程序实现如图:

    程序输入.png
    (图片转自https://blog.csdn.net/junwei0206/article/details/44988195
    答:代码如下:
    def filewrite(file_name):
        print('请输入内容【单独输入‘:w’保存退出】:')
        f = open(file_name, 'w')
        while True:
            a = input()
            if a != ':w':
                f.write('%s\n' % a)  # 注意这里有换行符
            else:
                break
    
        f.close()
    
    
    file_name = input('请输入文件名:')
    filewrite(file_name)
    

    运行过程如下:

    请输入文件名:1111.txt
    请输入内容【单独输入‘:w’保存退出】:
    123
    123
    456
    aaa
    啊啊啊
    
    :w
    
    Process finished with exit code 0
    

    文件打开查看:

    123
    123
    456
    aaa
    啊啊啊
    

    1. 编写一个程序,比较用户输入的两个文件,如果不同,显示出所有不同处的行号与第一个不同字符的位置,程序实现如图:

    1.png
    (图片转自https://blog.csdn.net/junwei0206/article/details/44988195
    答:代码如下:
    def file_compare(file1, file2):
        f1 = open(file1)
        f2 = open(file2)
        count = 0  # 统计行数
        differ = []  # 统计不一样的数量
        for line1 in f1:
            line2 = f2.readline()
            count += 1
            if line1 != line2:
                differ.append(count)
    
        f1.close()
        f2.close()
        return differ
    
    
    file1 = input('请输入需要比较的头一个文件名:')
    file2 = input('请输入需要比较的另一个文件名:')
    
    differ = file_compare(file1, file2)
    
    if len(differ) == 0:
        print('两个文件完全一样!')
    else:
        print('两个文件共有【%d】处不同:' % len(differ))
        print(differ)
        for each in differ:
            print('第%d行不一样' % each)
    

    输出:

    请输入需要比较的头一个文件名:1111.txt
    请输入需要比较的另一个文件名:33.txt
    两个文件共有【5】处不同:
    [7, 13, 22, 24, 29]
    第7行不一样
    第13行不一样
    第22行不一样
    第24行不一样
    第29行不一样
    

    2. 编写一个程序,当用户输入文件名和行数(N)后,将该文件的前N行内容打印到屏幕上,程序实现如图:

    2.png
    (图片转自https://blog.csdn.net/junwei0206/article/details/44988195
    答:代码如下:两种都可以
    def file_print(file, num):
        f = open(file)
        print('''文件%s的前%d行的内容如下:''' % (file, num))
        for i in range(num):
            print(f.readline())
        f.close()
    
    
    file_name = input('请输入要打开的文件(C:\\test.txt):')
    num = int(input('请输入需要显示该文件前几行:'))
    file_print(file_name, num)
    
    def file_view(file_name, line_nun):
        print('\n文件%s的前%s的内容如下:\n' % (file_name, line_num))
        f = open(file_name)
        for i in range(int(line_num)):
            print(f.readline(), end='')
        f.close()
    
    
    file_name = input(r'请输入要打开的文件(C:\\test.txt):')
    line_num = input('请输入需要显示该文件前几行:')
    file_view(file_name, line_num)
    

    3. 呃,不得不说我们的用户变得越来越刁钻了。要求在上一题的基础上扩展,用户可以随意输入需要显示的行数。(如输入13:21打印第13行到第21行,输入:21打印前21行,输入21:则打印从第21行开始到文件结尾所有内容)

    3.png
    (图片转自https://blog.csdn.net/junwei0206/article/details/44988195
    答:代码如下:
    def file_print(file, paragraph):
        (start, end) = paragraph.split(':')
        if start == '':
            start = 1
        else:
            start = int(start)
        if end == '':
            end = -1
        else:
            end = int(end)
    
        f = open(file)
        if start == 1:
            if end == -1:
                print('''文件%s的从开头到结束的内容如下:''' % file)
            else:
                print('''文件%s的从开头到第%d行的内容如下:''' % (file, end))
        else:
            if end == -1:
                print('''文件%s的从%d行到结束的内容如下:''' % (file, start))
            else:
                print('''文件%s的从第%d行到第%d行的内容如下:''' % (file, start, end))
    
        for i in range(start - 1):
            f.readline()
        num = end - start + 1
        if num < 0:
            print(f.read())
        else:
            for i in range(num):
                print(f.readline())
        f.close()
    
    
    file_name = input(r'请输入要打开的文件(C:\\test.txt):')
    paragraph = input('请输入需要显示的行数【格式如13:21或:21或21:】:')
    while paragraph == '':
        paragraph = input('输入有误,请重新输入:')
    file_print(file_name, paragraph)
    

    4. 编写一个程序,实现“全部替换”功能。

    答:代码如下:

    def file_replace(file_name, rep_word, new_word):
        f_read = open(file_name)
    
        content = []
        count = 0
    
        for each_line in f_read:
            if rep_word in each_line:
                count += each_line.count(rep_word)  # count感觉应该用这个
                each_line = each_line.replace(rep_word, new_word)
            content.append(each_line)
    
        decide = input('\n文件 %s 中共有%s个【%s】\n您确定要把所有的【%s】替换为【%s】吗?\n【YES/NO】:' \
                       % (file_name, count, rep_word, rep_word, new_word))
    
        if decide in ['YES', 'Yes', 'yes']:
            f_write = open(file_name, 'w')
            f_write.writelines(content)
            f_write.close()
    
        f_read.close()
    
    
    file_name = input('请输入文件名:')
    rep_word = input('请输入需要替换的单词或字符:')
    new_word = input('请输入新的单词或字符:')
    file_replace(file_name, rep_word, new_word)
    

    执行过程:

    请输入文件名:33.txt
    请输入需要替换的单词或字符:小丑鱼
    请输入新的单词或字符:小甲鱼
    
    文件 33.txt 中共有19个【小丑鱼】
    您确定要把所有的【小丑鱼】替换为【小甲鱼】吗?
    【YES/NO】:YES
    
    Process finished with exit code 0
    

    5.请写下这一节课你学习到的内容:格式不限,回忆并复述是加强记忆的好方式!

    • 任务:将文件(record.txt 下面我会用33.txt代替)中的数据进行分割并按照以下规律保存起来:
    • 小甲鱼的对话单独保存为boy_*.txt的文件(去掉“小甲鱼:”)
    • 小客服的对话单独保存为girl_*.txt的文件(去掉“小客服:”)
    • 文件中总共有三段对话,分别保存为boy_1.txt,girl_1.txt,boy_2.txt,
      girl_2.txt,boy_3.txt,girl_3.txt共6个文件(提示:文件中的不同对话见已经使用“=========”分割)

    注意:我下面的环境是python 3.7 + Mac
    代码如下:

    def save_file(boy, girl, count):
        file_name_boy = 'boy_' + str(count) + '.txt'
        file_name_girl = 'girl_' + str(count) + '.txt'
    
        boy_file = open('%s' % file_name_boy, 'w')
        girl_file = open('%s' % file_name_girl, 'w')
    
        boy_file.writelines(boy)
        girl_file.writelines(girl)
    
        boy_file.close()
        girl_file.close()
    
    
    def split_file(file_name):
        f = open(file_name)
        boy = []
        girl = []
        count = 1
    
        for each_line in f:
            if each_line[:6] != '======':
                (role, line_spoken) = each_line.split(':', 1)
                if role == '小甲鱼':
                    boy.append(line_spoken)
                if role == '小客服':
                    girl.append(line_spoken)
            else:
                save_file(boy, girl, count)
                count += 1
                boy = []
                girl = []
    
        save_file(boy, girl, count)
        f.close()
    
    
    split_file('33.txt')
    
    

    需要注意的几点:
    1、代码中的中文字符:
    (role,line_spoken) = each_line.split(':',1)
    其中,冒号应该是中文输入法下的':',否则会报错
    2、直接在record.txt所在目录下创建.py文件时,上述代码中的打开文件操作可以直接用文件名而不需要指明路径,即可以修改为:
    f.open('record.txt')
    上述两个文件不在同一目录下时,则应指明路径。
    3、上面这段代码在Python 3.7下运行老是报错:
    UnicodeDecodeError: 'utf-8' codec can't decode byte 0xbf in position 2: invalid start byte
    原因大概就是编码的问题,如果你要在mac上运行这个脚本的话,自己最好重新根据record.txt自己生成一个另外的文档,因为小甲鱼给的这个文档的编码方式或许在mac上不适用。可以自己新建一个文件,把record.txt内的内容复制过来即可。
    33.txt [百度云链接:https://pan.baidu.com/s/1FRR95vuwtgnywKywuV8uCA]


    相关文章

      网友评论

          本文标题:第二十九课:文件:一个任务

          本文链接:https://www.haomeiwen.com/subject/ouoxmftx.html