• Head First Python 学习笔记-Chapter3:文件读取和异常处理


    第三章中主要介绍了简单的文件读取和简单的异常处理操作。

    首先建立文件文件夹:HeadFirstPythonchapter3,在Head First Pythong官方站点下载须要使用的文件:sketch.txt,并放入到之前建好的文件夹中。

    相关语法

    读取文件

    the_file = open('sketch.txt)  # 打开文件,获取到文件对象
    # 对文件里的数据进行一些处理
    the_file.close() # 关闭文件

    异常捕获

    import sys
    
    try:
        # 可能会出现异常的代码
        f = open('myfile.txt')
        s = f.readline()
        i = int(s.strip())
    
    # 对异常进行处理
    # 相似于Java中的catch块
    except OSError as err: # 能够指定待捕获的异常
        print("OS error: {0}".format(err))
    except ValueError:
        pass # 不做不论什么操作,直接跳过
    except:
        print("Unexpected error:", sys.exc_info()[0])

    交互式环境下获取文件

    在python交互环境中(pyhton idle)中,能够使用例如以下的一些命令进行一些文件操作:

    >>> import os # 从标准库导入os
    >>> os.getcwd() # 获取当前的工作文件夹。相似于Linux下的pwd
    'D:\program\Python34'
    >>> os.chdir("D:codepythonHeadFirstPythonchapter3") # 切换工作文件夹
    >>> os.getcwd()
    'D:\code\python\HeadFirstPython\chapter3'
    
    >>> data = open('sketch.txt') # 打开文件,获取到文件对象,相当于一个迭代器iterator
    >>> print(data.readline(),end="") # 读取文件的一行,data.readline()
    Man: Is this the right room for an argument?
    >>> print(data.readline(),end="")
    Other Man: I've told you once.
    
    >>> data.seek(0) # 使data回到文件起始位置
    0
    
    # 使用for循环获得文件的每一行
    >>> for eachline in data:
        print(eachline,end="")

    对数据进一步的处理:异常处理

    再看一下文件里的数据,发现每一行都是用“:”进行分隔的。因此考虑在输出时进行优化。在对文件进行处理时,会出现对应的问题。比方文件里有些行是不含有“:”的,这时就会跑抛出ValueError异常,当文件不存在或者读取失败时,则会抛出IOError,等等。面对这些异常。有两种处理思路:
    1. 提前考虑好程序中可能出现的异常,对这些情况进行处理,从而避免异常的发生。
    2. 採用异常捕获机制:让异常发生,可是对异常进行捕获。捕获到后再进行相关的操作。

    第一种思路:

    import os
    if os.path.exists('sketch.txt'):
        data = open('sketch.txt')
        for each_line in data:
            if each_line.find(':') != -1:
                (role, line_spoken) = each_line.split(':', 1)
                print(role, end='')
                print(' said: ', end='')
                print(line_spoken,end='')
        data.close()
    else:
        print('文件不存在!

    ')

    另外一种思路:捕获异常:

    try:
        data = open('sketch2.txt')
        for each_line in data:
            # if each_line.find(':') != -1:
            try:
                (role, line_spoken) = each_line.split(':', 1)
                print(role, end='')
                print(' said: ', end='')
                print(line_spoken,end='')
            except:
                pass # 不做不论什么操作。直接跳过
        data.close()
    except:
        print('文件不存在')

    相关知识点

    1、split():对字符串进行切割。函数原型是str.split(sep=None, maxsplit=-1),它包括两个參数,第一个是使用切割符,第二个是最大切割次数。如:

    >>> '1,2,3'.split(',')
    ['1', '2', '3']
    >>> '1,2,3'.split(',', maxsplit=1)
    ['1', '2,3']
    >>> '1,2,,3,'.split(',')
    ['1', '2', '', '3', '']
    >>> '1 2 3'.split()
    ['1', '2', '3']
    >>> '1 2 3'.split(maxsplit=1)
    ['1', '2 3']
    >>> '   1   2   3   '.split()
    ['1', '2', '3']

    2、open():用来读取文件,同一时候创建了一个迭代器。能够对文件进行按行读取
    3、readline():读取文件的一行
    4、seek():将迭代器又一次指向文件的開始处(第一行)
    5、close():关闭打开的文件
    6、find():查找子串在字符串中的位置。不存在则返回-1

  • 相关阅读:
    进程总结
    三大流程
    canvas简介
    时钟
    vim
    马拉车
    模拟退火
    洛谷P2055假期的宿舍
    洛谷P2320鬼谷子的钱袋.
    洛谷P2278操作系统
  • 原文地址:https://www.cnblogs.com/cxchanpin/p/7220525.html
Copyright © 2020-2023  润新知