小甲鱼python笔记_小甲鱼Python笔记(下)

二十八 二十九 文件

打开文件 open(文件名[,模式][,缓冲])  注意open是个函数不是方法

模式:

461913-20150902154916716-283317646.png

缓冲:

大于1的数字代表缓冲区的大小(单位是字节),-1(或者是任何负数)代表使用默认缓冲区大小

只有用flush或者close时才会更新硬盘的数据

三种标准的流:

输入:sys.stdin 输出:sys.stdout 错误:sys.stderr

461913-20150902160114731-455136427.png

461913-20150902162401200-1151583395.png

用list()让文件成为一个列表,每一行是一个元素

461913-20150902162950903-602468641.png

用f.seek(0,0)还原文件指针到起始位置

用for读取文件中的每一行

461913-20150902163613731-1497702724.png

三十 os模块和os.path模块

Python os模块包含普遍的操作系统功能,注意括号中需要使用字符串

1.getcwd()

返回当前工作目录

2.chdir(path)

改变工作目录

3.listdir(path='.')

列举指定目录中的文件名('.'表示当前目录,'..'表示上一级目录)

4.mkdir(path)

创建单层目录,如该目录已存在抛出异常

5.makedirs(path)

递归创建多层目录,如该目录已存在抛出异常,注意:'E:\\a\\b'和'E:\\a\\c'并不会冲突

6.remove(path)

删除文件

7.rmdir(path)

删除单层目录,如该目录非空则抛出异常

8.removedirs(path)

递归删除目录,从子目录到父目录逐层尝试删除,遇到目录非空则抛出异常

9.rename(old, new)

将文件old重命名为new

10.system(command)

运行系统的shell命令

以下函数没有参数

11.os.curdir

指代当前目录('.')

12.os.pardir

指代上一级目录('..')

13.os.sep

输出操作系统特定的路径分隔符(Win下为'\\',Linux下为'/')

14.os.linesep

当前平台使用的行终止符(Win下为'\r\n',Linux下为'\n')

15.os.name

指代当前使用的操作系统(包括:'posix', 'nt', 'mac', 'os2', 'ce', 'java')

os.path模块

1.basename(path)

去掉目录路径,单独返回文件名

2.dirname(path)

去掉文件名,单独返回目录路径

3.join(path1[, path2[, ...]])

将path1, path2各部分组合成一个路径名

4,split(path)

分割文件名与路径,返回(f_path, f_name)元组。如果完全使用目录,它也会将最后一个目录作为文件名分离,且不会判断文件或者目录是否存在

5.splitext(path)

分离文件名与扩展名,返回(f_name, f_extension)元组

6.getsize(file)

返回指定文件的尺寸,单位是字节

7.getatime(file)

返回指定文件最近的访问时间(浮点型秒数,可用time模块的gmtime()或localtime()函数换算)

8.getctime(file)

返回指定文件的创建时间(浮点型秒数,可用time模块的gmtime()或localtime()函数换算)

9.getmtime(file)

返回指定文件最新的修改时间(浮点型秒数,可用time模块的gmtime()或localtime()函数换算)

以下为函数返回 True 或 False

10.exists(path)

判断指定路径(目录或文件)是否存在

11.isabs(path)

判断指定路径是否为绝对路径

12.isdir(path)

判断指定路径是否存在且是一个目录

13.isfile(path)

判断指定路径是否存在且是一个文件

14.islink(path)

判断指定路径是否存在且是一个符号链接

15.ismount(path)

判断指定路径是否存在且是一个挂载点

16.samefile(path1, paht2)

判断path1和path2两个路径是否指向同一个文件

三十一 pickle模块

以二进制保存数据

三步走:打开文件,用pickle.dump()方法将数据放入文件,关闭文件

1 importpickle2 my_list = [1,2,'老王',['abc']]3 pickle_file = open('my_list.pkl','wb') #文件名后缀无所谓

4 pickle.dump(my_list,pickle_file)5 pickle_file.close()

这样文件夹中就保存了my_list.pkl文件,(查询当前目录是用 import os os.getcwd())

读取数据

打开文件,调用pickle.load()方法

pickle_file = open('my_list.pkl','rb')

list2=pickle.load(pickle_file)print(list2)

三十二 三十三 异常

常见异常类型:

AttributeError:属性错误,特性引用和赋值失败时会引发属性错误

NameError:试图访问的变量名不存在

SyntaxError:语法错误,代码形式错误

Exception:所有异常的基类,因为所有python异常类都是基类Exception的其中一员,异常都是从基类Exception继承的,并且都在exceptions模块中定义。

IOError:一般常见于打开不存在文件时会引发IOError错误,也可以解理为输出输入错误

KeyError:使用了映射中不存在的关键字(键)时引发的关键字错误

IndexError:索引错误,使用的索引不存在,常索引超出序列范围,什么是索引

TypeError:类型错误,内建操作或是函数应于在了错误类型的对象时会引发类型错误

ZeroDivisonError:除数为0,在用除法操作时,第二个参数为0时引发了该错误

ValueError:值错误,传给对象的参数类型不正确,像是给int()函数传入了字符串数据类型的参数。

捕获异常

try语句一旦被检测出异常,剩下的语句将不会被执行

几种搭配:

1.try except

1 try:2 sum = 1/03 exceptZeroDivisionError:4 print('出错')

可以指明出错原因:

1 try:2 sum = 1/03 exceptZeroDivisionError as reason:4 print('出错,错误原因:',str(reason))

可以用多个except语句:

1 try:2 f = open("nofile.txt")3 sum = 1/04 exceptIOError as reason:5 print('出错,错误原因:',str(reason))6 exceptZeroDivisionError as reason:7 print('出错,错误原因:',str(reason))

461913-20150905205755170-2028432386.png

可以用一个元组捕获多个异常:

1 try:2 sum = 1/03 f = open("nofile.txt")4 except(IOError,ZeroDivisionError) as reason:5 print('出错,错误原因:',str(reason))

用while True 和 else 组合,else后的语句在没有异常的情况下才执行,注意缩进,输入错误后会重新输入直到正确:

1 whileTrue:2 try:3 x = int(input("input first num"))4 y = int(input("input first num"))5 z = x/y6 print(z)7 exceptZeroDivisionError:8 print("error,try again")9 else:10 break

不管try语句中是否发生异常,finally语句后都会执行:

1 try:2 x = int(input("input first num"))3 y = int(input("input first num"))4 z = x/y5 print(z)6 exceptZeroDivisionError:7 print("error:")8 finally:9 print("结束")

三十四 else和with

else:

if-else语句:

和各种语言相同的用法,在条件语句中,与if语句搭配使用的else语句。如果if语句的条件表达式的结果布尔值为假,那么程序将执行else语句后的代码。

elif(else-if)语句:

elif是python提供的else-if语句,它检查多个条件表达式的值是否为真,并在为真时执行特定代码块中的代码。和else一样,elif是可选的,但是要注意的是,一个if语句可以跟多个elif语句,但最后只能有一个else语句

while-else/for-else语句:

在其他语言中,除了条件语句,是不会见到else分支的,但在Python中,while和for循环中,也是可以使用else语句的。它们的工作顺序为:在循环中使用时,else语句只在循环完成后执行,也就是说,break语句也会跳过else代码块,只要循环是正常结束,而不是通过break,else语句就会执行

求素数:

1 deffun(num):2 count = int(num/2)3 while count>1:4 if(num%count ==0):5 print("%d的最大公约数是:%d" %(num,count))6 break

7 count -= 1

8 else:9 print("%d是素数" %num)10

11 n = int(input("请输入一个整数:"))12 fun(n)

执行结果:

461913-20150906090444061-1567846931.png

注意:Python中没有自增自减运算符,格式化输出多个字符要用元组的形式

try-else语句:

对于python中的错误和异常,try-except语句段,也可以和else连用,其功能和循环中的else语句没有多大区别:在try范围内没有检测到异常的时候,执行else子句。

with:

这个语法是用来代替传统的try...finally语法的。

with EXPRESSION [ as VARIABLE] WITH-BLOCK

1 try:2 with open("e://1.txt",'r') as f:3 for each_line inf:4 print(each_line)5 exceptIOError as reason:6 print("Error:",str(reason))

如果用finally,若是文件不存在,也要走f.close(),这样的话文件存在打开后会自动关闭

模块

(1)import 文件名  比如想导入tmp.py,在主程序中写import tmp,并用tmp.调用函数

(2)from 模块 import 函数(若要引用全部,写*)  在主程序中直接调用函数名

(3)import 文件名 as 别名  在主程序中用 别名. 调用函数

if __name__ == "__main__":

简单来说当一个文件作为模块时,在if __name__ == "__main__":语句后的内容不能被调用

原理:

461913-20150909202307215-1264847304.png

当作为模块时,可见__name__并不等于__main__,所以之后的东西不会执行,也不能被调用

搜索路径:用列表的方式添加或删除

461913-20150909201011762-1151317401.png

包:创建一个文件夹,文件夹中存放相应模块,文件夹的名字就是包的名字,在文件夹中创建一个__init__.py的模块文件,内容可以为空

使用包,import 包名.模块名

标准库

学习一个模块的方法,以timeit模块为例:

1.IDLE中F1,索引

2. IDLE中print(timeit.__doc__)查询模块说明

3. dir(timeit)查询所有用法

4. timeit.__all__查询对外接口

5. timeit.__file__查询源码路径

介绍timeit模块

爬虫

urllib

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值