标签:
文件处理
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:写博客也是一门技术活啊,这篇文章写完一看,感觉没什么用,而且断断续续的写了快一下午。真是佩服那些大神。
标签:
原文地址:http://www.cnblogs.com/fengbol/p/4835980.html