码迷,mamicode.com
首页 > 编程语言 > 详细

Head First Python学习笔记2——文件与异常

时间:2015-09-24 17:47:20      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:

文件处理

1.用open()就可以打开文件,但是请注意:文件里有中文请设置编码,如 :open("filepath","r",encoding="utf-8")本书没有说明这个,结果我输出的都是乱码,在网上找了好久才发现解决方法。第二个参数是文件读写模式,详细请看下面

  ‘r‘       打开读取文件(默认)
    ‘w‘      打开写入文件,会先清除文件内容
    ‘x‘       创建一个新文件不打开写入
    ‘a‘       如果文件存在,打开写入,并附加到文件末尾
    ‘b‘       二进制模式
    ‘t‘       文本模式(默认)   

    ‘+‘       打开一个磁盘上的文件并更新(读取和写入)

下面是一个简单的打开文件并读取内容的python代码

# 自python3开始默认使用unicode保存代码文件,所以可以直接使用中文了
# 导入os库
import os

os.chdir("workpath")    # 切换工作目录
os.getcwd()             # 查看当前工作目录
path = "新建文本文档.txt" # 如果没有切换工作目录,这里就要用绝对路径
data = open(path, "r", encoding="utf-8")   # 用utf-8格式打开文件,如果有中文请一定要指明编码格式,目前我看到的中文博客里基本都会提到中文编码的坑,所以前辈们的经验一定要注意啊
# 循环读取文件内容
for line in data:
    try:  # 异常处理
            print(line, end="")  # end=""是去掉换行符号
    except IOError as ie:   #as 也可以用于赋值
       print(str(ie))  #str() 用于转换成字符串,相当于c#里的ToString()    pass  # pass就是pass拉
data.seek(0)  # seek用于退回到起始位置(其实根据参数可以跳到指定位置,但0算是用的最多的) data.close()  # 一定要记得关闭

 2.字符串操作

split()和c#一样可以分离字符串,但是要注意参数是不返回的,比如strA.split(":")返回的字符串列表里没有:这点要注意,还有一个缺省参数用于指定分离成几个,默认是-1即有多少分离多少,比如是strA.split(":",1)则无论字符串里有多少个:都只会分裂成两个字符串,返回值是列表,可以直接a=strA.split(":")也可以(a,b)=strA.split(":"),一般情况下我建议前一种,除非你用strA.split(":",1)确定分离的数量,还有一点要注意,split返回的是用小括号包围的列表,即不可变列表,也称作元组(tuple)。而中括号包围的列表是可变列表。

find()有点类似c#里的indexOf,查询匹配项并返回下标,python里也有index()但是index()在找不到匹配项会报异常,而find()则返回-1,所以一般建议使用find,可以用参数指定查询范围,如strA.find(":",0,10)查询下标0至9的字符匹配,范围包含左边不含右边,记住哦。

还有一些函数就不一一细说了,如果有其他语言的编程经验,或者英语非常好的话,很多函数一看名称就知道是干什么的了,比如append()我不知道也没有这个单词,但我知道这一般是在最后附加,等等。这些东西还是要慢慢积累,不是一两本书就能说的完的。

Ps:写博客也是一门技术活啊,这篇文章写完一看,感觉没什么用,而且断断续续的写了快一下午。真是佩服那些大神。

 

Head First Python学习笔记2——文件与异常

标签:

原文地址:http://www.cnblogs.com/fengbol/p/4835980.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!