
Python open() 函数用于打开一个文件,并返回文件对象,在对文件进行处理过程都需要使用到这个函数,如果该文件无法被打开,会抛出 OSError。
注意:使用 open() 函数一定要保证关闭文件对象,即调用 close() 函数。
open() 函数常用形式是接收两个参数:文件名(file)和模式(mode)。
open(file, mode=‘r‘)完整的语法格式为:
open(file, mode=‘r‘, buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)参数说明:
mode 参数有:
| 模式 | 描述 | 
|---|---|
| t | 文本模式 (默认)。 | 
| x | 写模式,新建一个文件,如果该文件已存在则会报错。 | 
| b | 二进制模式。 | 
| + | 打开一个文件进行更新(可读可写)。 | 
| U | 通用换行模式(不推荐)。 | 
| r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 | 
| rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。 | 
| r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 | 
| rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。 | 
| w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 | 
| wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 | 
| w+ | 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 | 
| wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 | 
| a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 | 
| ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 | 
| a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 | 
| ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 | 
默认为文本模式,如果要以二进制模式打开,加上 b 。
content = ‘Python与Linux自动化运维‘
with open(‘read.txt‘,mode=‘w‘,encoding=‘utf-8‘) as f:
    f.write(content)
with open(‘read.txt‘,mode=‘r‘,encoding=‘utf-8‘) as f:
    print(f.read())Python与Linux自动化运维

with open(‘read.txt‘,mode=‘a‘,encoding=‘utf-8‘) as f:
    f.write(‘\nhello word\t你好‘)
with open(‘read.txt‘,mode=‘r‘,encoding=‘utf-8‘) as f:
    print(f.read())Python与Linux自动化运维 hello word 你好

img = ‘‘
with open(r"E:\软件\360壁纸\323244.jpg",mode=‘rb‘) as f:
    img = f.read()
    with open(‘11.jpg‘,mode=‘wb‘) as f1:
        f1.write(img)
with open(r‘C:\Users\huawei\Desktop\11.ts‘,mode=‘rb‘) as f:
    video = f.read()
    with open(‘11.ts‘,mode=‘wb‘) as f1:
        f1.write(video)
点开即可查看视频


异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。
一般情况下,在Python无法正常处理程序时就会发生一个异常。
异常是Python对象,表示一个错误。
当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执行。
捕捉异常可以使用try/except语句。
try/except语句用来检测try语句块中的错误,从而让except语句捕获异常信息并处理。
如果你不想在异常发生时结束你的程序,只需在try里捕获它。
以下为简单的try....except...else的语法:
try:
<语句>        #运行别的代码
except <名字>:
<语句>        #如果在try部份引发了‘name‘异常
except <名字>,<数据>:
<语句>        #如果引发了‘name‘异常,获得附加的数据
else:
<语句>        #如果没有异常发生try的工作原理是,当开始一个try语句后,python就在当前程序的上下文中作标记,这样当异常出现时就可以回到这里,try子句先执行,接下来会发生什么依赖于执行时是否出现异常。
你可以不带任何异常类型使用except,如下实例:
try:
    正常的操作
   ......................
except:
    发生异常,执行这块代码
   ......................
else:
    如果没有异常执行这块代码以上方式try-except语句捕获所有发生的异常。但这不是一个很好的方式,我们不能通过该程序识别出具体的异常信息。因为它捕获所有的异常。
try:
    #正常的代码
    with open(r‘E:\软件\360壁纸\32324.jpg‘,mode=‘rb‘) as f:
        img = f.read()
        with open(‘b.jpg‘,mode=‘wb‘) as f1:
            f1.write(img)
except FileNotFoundError:
    #出现错误后执行的代码
    print(‘文件路径错误‘)文件路径错误
try:
    # 根据运算符号确定运算规则
    if opt == ‘+‘:
        result = one + two
    elif opt == ‘-‘:
        result = one - two
    elif opt == ‘*‘:
        result = one * two
    elif opt == ‘/‘:
        if two ==0:
            print(‘0不能做除数‘)
        result = one /two
    print(result)
except ZeroDivisionError:
    print(‘需不能做除数!‘)请输入第一个数:1 请输入运算符号:/ 请输入第二个数:0 0不能做除数 需不能做除数!
使用except而带多种异常类型
你也可以使用相同的except语句来处理多个异常信息,如下所示:
try:
    正常的操作
   ......................
except(Exception1[, Exception2[,...ExceptionN]]]):
   发生以上多个异常中的一个,执行这块代码
   ......................
else:
    如果没有异常执行这块代码try:
    num = input(‘请输入数字‘)
    print (num+str(10))
except BaseException:
    print(‘输入类型错误! ‘)
else:
    print(‘hello‘)请输入数字11 1110 hello
try-finally 语句无论是否发生异常都将执行最后的代码。

try:
<语句>
finally:
<语句>    #退出try时总会执行
raisetry:
    fh = open("testfile", "w")
    fh.write("这是一个测试文件,用于测试异常!!")
finally:
    print "Error: 没有找到文件或读取文件失败"$ python test.py Error: 没有找到文件或读取文件失败
try:
    fh = open("testfile", "w")
    try:
        fh.write("这是一个测试文件,用于测试异常!!")
    finally:
        print "关闭文件"
        fh.close()
except IOError:
    print "Error: 没有找到文件或读取文件失败"当在try块中抛出一个异常,立即执行finally块代码。
finally块中的所有语句执行后,异常被再次触发,并执行except块代码。
参数的内容不同于异常。
Python 使用 raise 语句抛出一个指定的异常。
raise语法格式如下:
raise [Exception [, args [, traceback]]]
x = 10
if x > 5:
    raise Exception(‘x 不能大于 5。x 的值为: {}‘.format(x))Traceback (most recent call last):
  File "test.py", line 3, in <module>
    raise Exception(‘x 不能大于 5。x 的值为: {}‘.format(x))
Exception: x 不能大于 5。x 的值为: 10raise 唯一的一个参数指定了要被抛出的异常。它必须是一个异常的实例或者是异常的类(也就是 Exception 的子类)。
如果你只想知道这是否抛出了一个异常,并不想去处理它,那么一个简单的 raise 语句就可以再次把它抛出。
>>>try:
        raise NameError(‘HiThere‘)
    except NameError:
        print(‘An exception flew by!‘)
        raise
An exception flew by!
Traceback (most recent call last):
  File "<stdin>", line 2, in ?
NameError: HiThere一个异常可以带上参数,可作为输出的异常信息参数。
你可以通过except语句来捕获异常的参数,如下所示:
try:
    正常的操作
   ......................
except ExceptionType, Argument:
    你可以在这输出 Argument 的值...变量接收的异常值通常包含在异常的语句中。在元组的表单中变量可以接收一个或者多个值。
元组通常包含错误字符串,错误数字,错误位置。
| 异常名称 | 描述 | 
|---|---|
| BaseException | 所有异常的基类 | 
| SystemExit | 解释器请求退出 | 
| KeyboardInterrupt | 用户中断执行(通常是输入^C) | 
| Exception | 常规错误的基类 | 
| StopIteration | 迭代器没有更多的值 | 
| GeneratorExit | 生成器(generator)发生异常来通知退出 | 
| StandardError | 所有的内建标准异常的基类 | 
| ArithmeticError | 所有数值计算错误的基类 | 
| FloatingPointError | 浮点计算错误 | 
| OverflowError | 数值运算超出最大限制 | 
| ZeroDivisionError | 除(或取模)零 (所有数据类型) | 
| AssertionError | 断言语句失败 | 
| AttributeError | 对象没有这个属性 | 
| EOFError | 没有内建输入,到达EOF 标记 | 
| EnvironmentError | 操作系统错误的基类 | 
| IOError | 输入/输出操作失败 | 
| OSError | 操作系统错误 | 
| WindowsError | 系统调用失败 | 
| ImportError | 导入模块/对象失败 | 
| LookupError | 无效数据查询的基类 | 
| IndexError | 序列中没有此索引(index) | 
| KeyError | 映射中没有这个键 | 
| MemoryError | 内存溢出错误(对于Python 解释器不是致命的) | 
| NameError | 未声明/初始化对象 (没有属性) | 
| UnboundLocalError | 访问未初始化的本地变量 | 
| ReferenceError | 弱引用(Weak reference)试图访问已经垃圾回收了的对象 | 
| RuntimeError | 一般的运行时错误 | 
| NotImplementedError | 尚未实现的方法 | 
| SyntaxError | Python 语法错误 | 
| IndentationError | 缩进错误 | 
| TabError | Tab 和空格混用 | 
| SystemError | 一般的解释器系统错误 | 
| TypeError | 对类型无效的操作 | 
| ValueError | 传入无效的参数 | 
| UnicodeError | Unicode 相关的错误 | 
| UnicodeDecodeError | Unicode 解码时的错误 | 
| UnicodeEncodeError | Unicode 编码时错误 | 
| UnicodeTranslateError | Unicode 转换时错误 | 
| Warning | 警告的基类 | 
| DeprecationWarning | 关于被弃用的特征的警告 | 
| FutureWarning | 关于构造将来语义会有改变的警告 | 
| OverflowWarning | 旧的关于自动提升为长整型(long)的警告 | 
| PendingDeprecationWarning | 关于特性将会被废弃的警告 | 
| RuntimeWarning | 可疑的运行时行为(runtime behavior)的警告 | 
| SyntaxWarning | 可疑的语法的警告 | 
| UserWarning | 用户代码生成的警告 | 
以下为单个异常的实例:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 定义函数
def temp_convert(var):
    try:
        return int(var)
    except ValueError, Argument:
        print "参数没有包含数字\n", Argument
# 调用函数
temp_convert("xyz");以上程序执行结果如下:
$ python test.py 参数没有包含数字 invalid literal for int() with base 10: ‘xyz‘
我们可以使用raise语句自己触发异常
raise语法格式如下:
raise [Exception [, args [, traceback]]]语句中 Exception 是异常的类型(例如,NameError)参数标准异常中任一种,args 是自已提供的异常参数。
最后一个参数是可选的(在实践中很少使用),如果存在,是跟踪异常对象。
一个异常可以是一个字符串,类或对象。 Python的内核提供的异常,大多数都是实例化的类,这是一个类的实例的参数。
定义一个异常非常简单,如下所示:
def functionName( level ):
    if level < 1:
        raise Exception("Invalid level!", level)
        # 触发异常后,后面的代码就不会再执行注意:为了能够捕获异常,"except"语句必须有用相同的异常来抛出类对象或者字符串。
例如我们捕获以上异常,"except"语句如下所示:
try:
    正常逻辑
except Exception,err:
    触发自定义异常    
else:
    其余代码#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 定义函数
def mye( level ):
    if level < 1:
        raise Exception,"Invalid level!"
        # 触发异常后,后面的代码就不会再执行
try:
    mye(0)            # 触发异常
except Exception,err:
    print 1,err
else:
    print 2执行以上代码,输出结果为:
$ python test.py 1 Invalid level!
通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception类,通过直接或间接的方式。
以下为与RuntimeError相关的实例,实例中创建了一个类,基类为RuntimeError,用于在异常触发时输出更多的信息。
在try语句块中,用户自定义的异常后执行except块语句,变量 e 是用于创建Networkerror类的实例。
class Networkerror(RuntimeError):
    def __init__(self, arg):
        self.args = arg在你定义以上类后,你可以触发该异常,如下所示:
try:
    raise Networkerror("Bad hostname")
except Networkerror,e:
    print e.argsfrom 文件和异常.总结.network_error import NetWorkError
try:
    with open(r"E:\软件\360壁纸\323244.jpg", mode=‘rb‘) as f:
        img = f.read()
    with open(‘b.jpg‘, mode=‘wb‘) as f1:
        f1.write(img)
except (FileNotFoundError,IndexError, ValueError):
    print(‘except‘)
    raise NetWorkError(‘application bad ...‘)
else:
    print(‘else‘)
finally:
    print(‘finally‘)class NetWorkError(RuntimeError):
    def __init__(self,arg):
        self.arg=argJSON (JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。
Python3 中可以使用 json 模块来对 JSON 数据进行编解码,它包含了两个函数:
在json的编解码过程中,python 的原始类型与json类型会相互转换,具体的转化对照如下:
| Python | JSON | 
|---|---|
| dict | object | 
| list, tuple | array | 
| str | string | 
| int, float, int- & float-derived Enums | number | 
| True | true | 
| False | false | 
| None | null | 
import json
username = input(‘请输入用户名:‘)
filename = ‘user.json‘
with open(filename,‘w‘) as f:
    json.dump(username,f)
    print(‘您输入的用户名已保存到json文件中。‘)请输入用户名:xgp 您输入的用户名已保存到json文件中。
import json
filename = ‘user.json‘
with open(filename) as f:
    username = json.load(f)
    print(‘欢迎‘+username+".")欢迎xgp.
import json
numbers = [1,2,3,4,5]
filename = ‘num.json‘
with open(filename,‘w‘) as f:
    json.dump(numbers,f)以下实例演示了 Python 数据结构转换为JSON:
import json
# Python 字典类型转换为 JSON 对象
data = {
    ‘no‘ : 1,
    ‘name‘ : ‘Runoob‘,
    ‘url‘ : ‘http://www.runoob.com‘
}
json_str = json.dumps(data)
print ("Python 原始数据:", repr(data))
print ("JSON 对象:", json_str)Python 原始数据: {‘url‘: ‘http://www.runoob.com‘, ‘no‘: 1, ‘name‘: ‘Runoob‘} JSON 对象: {"url": "http://www.runoob.com", "no": 1, "name": "Runoob"}
通过输出的结果可以看出,简单类型通过编码后跟其原始的repr()输出结果非常相似。
接着以上实例,我们可以将一个JSON编码的字符串转换回一个Python数据结构:
import json
# Python 字典类型转换为 JSON 对象
data1 = {
    ‘no‘ : 1,
    ‘name‘ : ‘Runoob‘,
    ‘url‘ : ‘http://www.runoob.com‘
}
json_str = json.dumps(data1)
print ("Python 原始数据:", repr(data1))
print ("JSON 对象:", json_str)
# 将 JSON 对象转换为 Python 字典
data2 = json.loads(json_str)
print ("data2[‘name‘]: ", data2[‘name‘])
print ("data2[‘url‘]: ", data2[‘url‘])Python 原始数据: {‘name‘: ‘Runoob‘, ‘no‘: 1, ‘url‘: ‘http://www.runoob.com‘} JSON 对象: {"name": "Runoob", "no": 1, "url": "http://www.runoob.com"} data2[‘name‘]: Runoob data2[‘url‘]: http://www.runoob.com
如果你要处理的是文件而不是字符串,你可以使用 json.dump() 和 json.load() 来编码和解码JSON数据。例如:
# 写入 JSON 数据
with open(‘data.json‘, ‘w‘) as f:
    json.dump(data, f)
# 读取数据
with open(‘data.json‘, ‘r‘) as f:
    data = json.load(f)原文:https://blog.51cto.com/14320361/2486142