python异常和文件处理机制详解


Posted in Python onJuly 19, 2016

本文实例讲述了python异常和文件处理机制。分享给大家供大家参考,具体如下:

1 异常处理

Python的异常用
try
except
finally
来处理. 并且except后还可以跟 else .

引发异常用 raise

如果抛出的异常没有被处理. 在Python IDE中是显示一些红色的信息. 在真正的Python程序运行时. 会导致程序终止.

在以前我们已经见到过一下几种异常:

在 Dictionary 中如果使用的 key 不存在. 会引发 KeyError 异常. 如:

>>> d = {"a":1, "b":"abc"}
>>> d["c"]
Traceback (most recent call last): File "<interactive input>", line 1, in <module>
KeyError: 'c'

搜索列表中不存在的值. 将引发 ValueError 异常. 如:

>>> li = [1,2]
>>> li.index(3)
Traceback (most recent call last): File "<interactive input>", line 1, in <module>
ValueError: list.index(x): x not in list

对应的. 若用下标来引用列表中的元素. 若下标出界. 会产生 IndexError 异常. 如:

>>> li[2]
Traceback (most recent call last):
 File "<interactive input>", line 1, in <module>
IndexError: list index out of range

调用不存在的方法. 会引发 AttributeError 异常.

引用不存在的变量. 引发 NameError 异常.

未强制转化就混用数据类型. 引发 TypeError 异常.

文件操作错误引发的 IOError. 如:

try:
  fsock = open("/notthere")
except IOError:
  print "The file dose not exits..."
else:
  print "open the file."
print "this line will always print"

注意上边的代码中:

open 是一个内置函数. 用来打开文件. 并返回一个文件对象.
try except 后边可以跟 else 语句. 当没有捕捉到指定的异常时. 执行else 语句.

导入一个模块时. 若模块不存在. 会引发 ImportError 异常.

还可以定义自己的异常类. 定义时让它继承内置的 Exception 类. 然后在需要抛出异常时用 raise 抛出.

2 与文件对象共事

前面说过用 open 可以打开文件并返回文件对象. 它的函数声明如下:

open(name[, mode[, buffering]])

有3个参数(其中后两个是可选的). 分别表示 文件名. 打开方式. 缓冲区参数. 例如:

>>> f = open("/music/_singles/kairo.mp3", "rb")

第2个参数指定为"rb". 表示以2进制读打开文件.  如果这个参数缺省. 则表示以文本方式打开.

如果不能打开. 则open引发 IOError 异常.

现在可以用文件对象的 name 属性和 mode 属性来查询它们. 如:

>>> f.name
'/music/_singles/kairo.mp3'
>>> f.mode
'rb'

打开文件后. 就可以进行读写了. 如:

>>> f.tell()

查询当前位置.

0
>>> f.seek(0, 2)

定位文件指针. 第一个参数是偏移值. 第二个可以取0. 1. 2三个值. 分别表示开头. 当前位置. 末尾.

若定位的地址不正确(例如超过范围) 则引发IOError异常.

所以这个语句就把文件指针定位到了文件尾.

>>> f.tell()

这将打印文件的长度.

>>> f.seek(-128, 2)
>>> data = f.read(128)

读取文件的最后128字节. 并将读入的的数据作为字符串返回. 读取数据时也同时后移文件指针.

其中 read 的参数表示最大读取字节数. 也可以省略这个参数. 则表示一直读到文件末尾.

若读取时出现错误(如磁盘上有坏扇区或网络已断开). 引发IOError 异常.

>>> f.closed

查看文件是否关闭.

False
>>> f.close()

不再使用时应该关闭文件. 可以对一个已经关闭的文件再次关闭(不会发生异常).

>>> f.closed
True

关闭之后如果再对 f 进行 seek() 等操作. 会引发 ValueError 异常.
写入文件的办法和读取类似. 不过它要求文件是 "写" 打开的. 如:

>>> f1 = open('test.log', 'w')

其中 'w' 表示写打开. 这样即使文件不存在. 也会创建. 如果存在. 则覆盖现有的文件.

>>> f1.write('abc')
>>> f1.close()
>>> file('test.log').read()

用 file()打开文件和用open()打开是一样的. 所以打印:

'abc'

3 for循环

在Python中. for用来在一个List上遍历. 如:

>>> li = [1, 2, 3]
>>> for i in li:

这会在循环中让 i 依次接收 li 中的元素的值.

...  print i
...
1
2
3

这个输出和 print "\n".joni(li) 一样.
如果要象其它语言中一样. 让for做计数使用. 可以用如下的办法:

>>> for i in range(len(li)) : print li[i]
...
1
2
3

要用 for 来遍历 Dictionary . 如下:

>>> d = {1:"abc", 2:"def"}
>>> for k, v in d.items() : print "%d = %s" % (k, v)
...
1 = abc
2 = def

上边的打印结果和 print "\n".join(["%d = %s" % (k, v) for k, v in d.items()]) 一样.

4 使用 sys.modules

在Python中. modules 是定义在sys模块中的一个全局的字典对象.

一旦我们import一个模块. 就可以在 sys.modules 中找到它.

每个类都拥有一个内置的"类属性" : __module__ . 其值为定义该类的模块的名字.

5 与Directory共事

在os.path 所引用的模块中有几个操作文件和目录的函数.如:

>>> import os
>>> os.path.join("c:\music", "mahadeva.mp3")

这个join函数用来将一个或多个字符串构造成一个路径名.

'c:\music\mahadeva.mp3'
>>> os.path.expanduser("~")

expanduser函数用'~'作参数时. 返回当前用户根目录.
'c:\Documents and Settings\mpilgrim\My Documents'

>>> (filepath, filename) = os.path.split("c:\music\a.mp3")

split函数用来将一个路径名分成目录名和文件名. 它返回的是一个tuple. 用返回的tuple对(filepath, filename)赋值.

>>> filepath
'c:\music'
>>> filename
'a.mp3'
>>> (a, b) = os.path.splitext("a.mp3")

类似的. 这个splitext用来将一个全文件名分成 文件名 和 扩展名 两部分.

>>> a
'a'
>>> b
'.mp3'

列出目录用:

>>> os.listdir("c:\")

这个函数将返回一个字符串list. 包括所有的文件和文件夹的名字.

['boot.ini', 'CONFIG.SYS', 'AUTOEXEC.BAT', 'java', 等]

要判断一个字符串路径到底是一个文件还是一个文件夹. 用os.path模块中的 isfile() 或 isdir(). 如:

>>> [f for f in os.listdir("c:") if os.path.isdir(os.path.join("c:", f))]

这样就打印出c中所有文件夹名构成的list.

如果要在目录操作中使用通配符. 可以如下:

>>> import glob

要先导入 glob 模块

>>> glob.glob('c:\music\*.mp3')

则返回的list中包含了该目录下所有的 .mp3 后缀的文件名.

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python中删除文件的程序代码
Mar 13 Python
Python判断Abundant Number的方法
Jun 15 Python
Python 对输入的数字进行排序的方法
Jun 23 Python
Python实现E-Mail收集插件实例教程
Feb 06 Python
详解pandas的外部数据导入与常用方法
May 01 Python
python实践项目之监控当前联网状态详情
May 23 Python
Python音频操作工具PyAudio上手教程详解
Jun 26 Python
Django 数据库同步操作技巧详解
Jul 19 Python
python搜索包的路径的实现方法
Jul 19 Python
学python爬虫能做什么
Jul 29 Python
python实现跨年表白神器--你值得拥有
Jan 04 Python
解决pytorch-gpu 安装失败的记录
May 24 Python
python线程、进程和协程详解
Jul 19 #Python
浅谈python字符串方法的简单使用
Jul 18 #Python
python读取oracle函数返回值
Jul 18 #Python
Python读取一个目录下所有目录和文件的方法
Jul 15 #Python
Python在线运行代码助手
Jul 15 #Python
python 实现网上商城,转账,存取款等功能的信用卡系统
Jul 15 #Python
python 性能提升的几种方法
Jul 15 #Python
You might like
使用sockets:从新闻组中获取文章(一)
2006/10/09 PHP
网友原创的PHP模板类代码
2008/09/07 PHP
php生成QRcode实例
2014/09/22 PHP
简单谈谈php中ob_flush和flush的区别
2014/11/27 PHP
WordPress中查询文章的循环Loop结构及用法分析
2015/12/17 PHP
PHP基于IMAP收取邮件的方法示例
2017/08/07 PHP
DOMAssitant最新版 DOMAssistant 2.5发布
2007/12/25 Javascript
JavaScript 轻松搞定快捷留言功能 只需一行代码
2010/04/01 Javascript
innerHTML 和 getElementsByName 在IE下面的bug 的解决
2010/04/09 Javascript
Javascript中Event属性搜集整理
2013/09/17 Javascript
javascript右下角弹层及自动隐藏(自己编写)
2013/11/20 Javascript
Jquery解析json数据详解
2013/12/26 Javascript
jQuery中before()方法用法实例
2014/12/25 Javascript
jQuery实现鼠标点击弹出渐变层的方法
2015/07/09 Javascript
理解jquery事件冒泡
2016/01/03 Javascript
JavaScript数组复制详解
2017/02/02 Javascript
修改Nodejs内置的npm默认配置路径方法
2018/05/13 NodeJs
vue发送ajax请求详解
2018/10/09 Javascript
微信小程序实现侧边分类栏
2019/10/21 Javascript
在node环境下parse Smarty模板的使用示例代码
2019/11/15 Javascript
解决ant Design中Select设置initialValue时的大坑
2020/10/29 Javascript
浅谈python函数之作用域(python3.5)
2017/10/27 Python
python 将有序数组转换为二叉树的方法
2019/03/26 Python
django-filter和普通查询的例子
2019/08/12 Python
python+selenium 鼠标事件操作方法
2019/08/24 Python
详解python3中用HTMLTestRunner.py报ImportError: No module named 'StringIO'如何解决
2019/08/27 Python
python线程中的同步问题及解决方法
2019/08/29 Python
Russell Stover巧克力官方网站:美国领先的精美巧克力制造商
2016/11/27 全球购物
华硕新加坡官方网上商店:ASUS Singapore
2020/07/09 全球购物
小学教师的个人自我鉴定
2013/10/26 职场文书
优秀演讲稿范文
2013/12/29 职场文书
人事档案接收函
2014/01/12 职场文书
创业计划书——互联网商机
2014/01/12 职场文书
水电工岗位职责
2014/02/12 职场文书
2015年春训学习心得体会范文
2015/03/09 职场文书
员工拾金不昧表扬稿
2015/05/05 职场文书