不同模式打开文件的完全列表:
模式 | 描述 |
---|---|
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。 |
w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
w+ | 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
有文件config.txt如下,要读取文件中的值
m_url=https://onetouch-partner.aba.com/login.htm? b_url=https://onetouch-partner.aba.com/ptnBasedata/crm/ c_url=https://onetouch-partner.aba.com/ptnBasedata/crm/customerList.htm titls=[公司名称,创建时间,访问时间,生成时间,签约情况,跟进情况,公司地址,联系人姓名,电话,企业邮箱,联系人邮箱] filename=客户信息 word=IDL2020888**
file 对象方法
f.read([size]):size 未指定则返回整个文件,如果文件大小 >2 倍内存则有问题,f.read()将整个文件内容作为一个字符串,读到文件尾时返回""(空字串)。
f.readline():返回一行。
f.readlines([size]) :返回包含size行的列表, size 未指定则返回全部行。
for line in f: print line :通过迭代器访问。
f.write("hello
"):如果要写入字符串以外的数据,先将他转换为字符串。
f.close() 关闭文件
绝对路径就是文件的真正存在的路径,是指从硬盘的根目录(盘符)开始,进行一级级目录指向文件。
相对路径就是以当前文件为基准进行一级级目录指向被引用的资源文件。
../ 表示当前文件所在的目录的上一级目录
./ 表示当前文件所在的目录(可以省略)
/ 表示当前站点的根目录(域名映射的硬盘目录)
py文件与要读取文件在统一目录下可直接读取,不用家路径
python中转义用\,路径用/,因此windows路径可以是/(与linux一致)也可以用\,Unix和Web用正斜杠/,Windows用反斜杠,但是现在Windows
python读文件需要输入的目录参数,以下path都是正确的:
path1 = r"C:Windows emp
eadme.txt" # ""为字符串中的特殊字符,加上r后变为原始字符串,则不会对字符串中的" "、"
" 进行字符串转义
path2 = "c:\windows\temp\readme.txt" # 用一个""取消第二个""的特殊转义作用,即为"\"
path3 = "c:/windows/temp/readme.txt" # 用正斜杠做目录分隔符也可以转到对应目录,并且在python中path3的方式也省去了反斜杠转义的烦恼
def read_myconfig(): ss=[] f = open("config.txt",'r',encoding='utf-8') #返回一个文件对象 # print(f) for line in f: ss.append(line.split('=')[1].strip(" ")) f.close() print(ss) read_myconfig() def read_myconfig(): ss=[] f = open("config.txt",'r+',encoding='utf-8') #返回一个文件对象 line = f.read() #调用文件的 readline()方法 f.close() # print(line.split(' ')) for i in (line.split(' ')): ss.append(i.split('=')[1])#以每行的换行划分,将每行作为列表的一个元素。 print(ss) read_myconfig() def read_myconfig(): ss=[] f = open("config.txt",'r+',encoding='utf-8') #返回一个文件对象 line = f.readline() #调用文件的 readline()方法 # print(line) while line: ss.append(line.split()[0].split('=')[1])#先过滤掉行末的换行 line = f.readline() f.close() print(ss) read_myconfig() def read_myconfig(): ss=[] f = open("config.txt",'r',encoding='utf-8') #返回一个文件对象 line = f.readlines() #调用文件的 readline()方法 f.close() # print(line) for i in line: ss.append(i.split('=')[1].strip(" ")) print(ss) read_myconfig() def read_myconfig(): f = open("config.txt",'r',encoding='utf-8') #返回一个文件对象 line = f.readlines() #调用文件的 readline()方法 f.close() # print(line) ss=[i.split('=')[1].strip(" ") for i in line] print(ss) read_myconfig()
结果如下:
['https://onetouch-partner.aba.com/login.htm?', 'https://onetouch-partner.aba.com/ptnBasedata/crm/',
'https://onetouch-partner.aba.com/ptnBasedata/crm/customerList.htm',
'[公司名称,创建时间,访问时间,生成时间,签约情况,跟进情况,公司地址,联系人姓名,电话,企业邮箱,联系人邮箱]', '客户信息', 'IDL2020888**']
在python中存在继承了 回车符 和 换行符 两种标记
aa='https://
one touch-pa rtner.aba.com/login.htm?
'
print(aa.replace('
', '').replace('
', '') ) 去掉 aa字符内所有的 回车符和换行符
print(aa.replace(' ', '') ) 去掉 aa字符内所有的 空格
print(aa.strip()) 只能够去除aa字符串首尾的空格,不能够去除中间的空格
常用的配置文件后缀是.ini、.conf、.py,当然还有使用.json、.txt的,推荐使用常用的.ini、.py
用Python变量作为配置文件格式
相信大部分Python程序员都不会陌生,把配置直接用变量的形式写到一个模块中,在需要读取配置的地方,直接import模块就能得到配置变量。这得益于:
l Python是解释性语言,无需编译,修改后的源文件直接可以运行;
l Python优雅的语法,直观的变量定义,灵活的数据类型。
配置文件示例:
# config.py
listen_port = 4444
use_epoll = True
...
在读取配置的地方:
import config
port_num = config.listen_port
if config.use_epoll:
...
优点
直接用python变量作为配置文件格式的优点是显然的:
l 不用任何解释器来解释配置文件。Python解释器本身就可以。
l 使用自然、方便,直接可用,和其他变量的使用没有任何区别。
l 学习成本低,不需要学习其他配置文件的格式和语法。
缺点
方便之处在于不用parser,缺点也在于不用parser。通常情况,配置文件是人负责写,程序负责读。但如果配置文件既要让人写也要让代码写。比如程序的配置可以直接改配置文件,同时也提供了一套界面让用户在界面上修改配置。在界面上修改的配置,最终也是反映到配置文件中,这就要求代码修改配置文件了。此时会有少许不便。
用.ini、.tx作为配置文件格式
.ini、.txt配置文件使用方法是一致的,只是一个后缀的区别,这里以ini配置文件来介绍,这类配置文件我们使用内置configparser库来使用,它可以实现配置文件的写入、更新、删除、读取等操作非常方便,建议使用这种方式。新建一个config.ini的配置文件内容如下:
[mysql] name = admin host = 255.255.255.0 proxy = 6037 password = 123456 pool = true time = 3 #其中[]中的是section节点,该节点下的等式是键值对
常用方法如下:
# -*- coding: utf-8 -*- import configparser config = configparser.ConfigParser() config.read("Config.ini", encoding="utf-8") config.sections() # 获取section节点 config.options('mysql') # 获取指定section 的options即该节点的所有键 config.get("mysql", "name") # 获取指定section下的options config.items("mysql") # 获取section的所用配置信息 config.set("mysql", "name", "root") # 修改值 config.has_section("mysql") # 是否存在该section config.has_option("mysql", "password") # 是否存在该option config.add_section("redis") # 添加section节点 config.set("redis", "name", "redis_admin") # 设置指定section 的options config.remove_section("redis") # 整个section下的所有内容都将删除 config.remove_option("mysql", 'time') # 删除section下的指定options config.write(open("Config", "w")) # 保存config