Python学习总结【连载】(十)

Python学习总结【连载】(十)

2018.06.25 Juttachen


概述

+ 32 文本文件的读写

  • 文件的概念
  • 文件操作步骤
  • 在python中打开文件
  • 修改读取的位置
  • 文件的写操作

+ 33 二进制文件的操作

+ 34 json文件的读写

+ 35 捕获异常


三十二、文件操作

1.文件的概念

文件可以永久保存数据
a.文件的分类
文件都有后缀,不同的后缀表示不同的存储方式。
文本文件(存文字信息) --.txt, .word, .md等
二进制文件:视频文件、音频、图片 --.mp4, .mov, .avi, .mp3, .png, .jpg, .gif等
可执行文件等 --.exe, .api, .dmg等

2.文件操作的步骤:(适应于所有文件)

a.打开文件
b.操作
c.关闭

3.在Python中打开文件

open(文件路径,打开方式,编码方式)
补充:
文件路径:
1.绝对地址(/Users/yuting/aaa.txt)
2.相对地址(./相对路径)-->相对于当前工程目录
打开方式:
'r' ---> 读(默认)
'w' ---> 写(1.覆盖原文件内容)
'a' ---> 写(在原文件内容后追加)
注意:文本文件的内容,对应的就是字符串.

a.读操作

    f = open('test.txt', 'r',   encoding='utf-8')
    print(f.read())
    f.close()

注意: 如果文件的路径写错了会报:FileNotFoundError

b.写操作

    f1 = open('test1.txt', 'w', encoding='utf-8')
    f1.write('1234567')
    f1.close()

    f1 = open('test2.txt', 'a', encoding='utf-8')
    f1.write('1234567')
    f1.close()

注意:'w'、'a'打开文件,如果这个文件不存在,会创建一个新的文件

c.在Python中特有的方法

在python中可以使用以下结构来进行文件操作过程:
with open() as 文件变量:
在文件打开后关闭前执行的代码段

这种方式可以自动在缩进块运行完后关闭文件。

    with open('test.txt', 'r',   encoding='utf-8') as f:
        print(f.read())

4.修改读取的位置

a.python读取的特点

读文件,每次读完,下次再读的时候,是接着上次读完的位置往下进行读操作

b.如何从头开始读?

1)重新打开文件,然后再读
2)设置读写位置(使用seek()方法)

    f = open('test.txt', 'r', encoding='utf-8')
    # 读取文件中所有的内容,下次再读就是从文件结束的位置往后读
    print(f.read())
    f.seek(0)
    print('==:', f.read())
    f.close()

seek(偏移量):
偏移量:字节数(一个字母是一个字节,一个中文汉字是两个字节)
设置读写位置为文件的开始: 后边进行读操作的时候,就是从文件开始的偏移量后的位置往后读
注意: 偏移量一般设置为0

4.文件的写操作

    f = open('test.txt', 'a', encoding='utf-8')
    f.write('窗前明月光,\n 疑是地上霜')

write(写的内容): 文本文件中写的内容是字符串
注意: 'w'-> 写的时候会覆盖原文件的内容 'a' -> 在原来的内容的后面去追加内容

    f.seek(0)  # 后面写的时候,会以覆盖前面写的内容的形式去写
    f.writelines(['aaaa', 'bbbb', 'ccccc','hhhhhhh'])
    f.close()

三十三、二进制文件的操作

1.二进制文件的读

    with open('./files/chuangxu.png', 'br') as f:
        data = f.read()
        print('===:',type(data)) #bytes类: python中的二进制数据对应的类型是bytes --> data
        # print(reslut)

2.二进制文件的写

    with open('./files/new.png', 'bw') as f:
        # data需要是bytes类型的数据
        f.write(data)
    # 'ba':无追加效果

三十四、json文件的读写

json文件: 就是后缀是.json的文件,用来存储文本数据(以特殊的语法结构来存储文本信息)

1.json文件的结构

最外层要么是字典结构,要么是数组(列表)结构
里面的数据:字符串、数字、二进制、字典、数组(列表)
{} -> 字典结构
{
"name":"aa",
"age":18,
"score":[100, 90, 80]
}

[] -> 数组(列表)结构
[
100,
"name",
"person":{"name":"张三", "age":30}
]

"" -> 字符串(只能用双引号括起来才行)
"
name ,sfjk,{ksjjdk},kksjkjk
"

2.json文件的读写

python中使用python内置模块json来对json数据进行操作

    import json

a.读取json文件中的内容

json.load(f):读的结果只有两种情况:要么是字典、要么是列表

    with open('./files/myjson.json','r', encoding='utf-8') as f:
        result = json.load(f)
        print(type(result))
        print(result)

b.json文件的写操作

son.dump(写的内容,f): 写的内容只能是字典或者列表

    with open('./files/myjson.json', 'w', encoding='utf-8') as f:
        # dict1 = {'aaa': 100, 'score': 99, 'person': {'name':'王海飞', 'age':30}}
        # json.dump(dict1, f)

        # list1 = [10, 20, 'a', 'abc']
        # json.dump(list1, f)

        tuple1 = (10, 20, 'abc')  # 写进去还是列表
        json.dump(tuple1, f)

        # json.dump('abcnd', f)

三十五、异常捕获

由于各种原因,我们的代码会出现各种各样的错误(ValueError,FileNotFoundError,IndexError,KeyError)。这些错误我们叫异常,如果程序出现异常,程序会崩溃,不能继续执行。
但是,有的时候出现异常,我们可能希望由自己解决出现异常的问题,不希望程序崩溃,就可以捕获异常。

1.格式:

格式1
try:
代码块1(需要捕获异常的代码块)
except:
代码块2(出现异常后执行的)

执行过程:
先执行代码块1,如果执行代码块1的时候出现异常,就执行代码块2;
如果代码块1不出现异常,就执行try结构外的其他语句

    try:
        print(int('12sd'))
        with open('./files/test1.json', 'r', encoding='utf-8') as f:
             pass
    except:
        print('出现异常了')

    print('aaa')

格式2
try:
代码块1
except 错误类型列表:
代码块2

出现指定错误类型的异常,才捕获

    try:
        a = [1, 2, 3]
        print(a[10])
        with open('./files/test1.json', 'r', encoding='utf-8') as f:
            pass
    except FileNotFoundError:
        print('出现文件找不到异常')
    except ValueError:
        print('值错误异常')
    except:
        print('其他异常出现')
    finally:
        print('不管有没有异常都要执行')
    print('aaa')

你可能感兴趣的:(Python学习总结【连载】(十))