python开发项目,不得不了解的.cfg配置文件

liftword1周前 (12-30)技术文章11

安装软件时,经常会见到后缀为.cfg、.ini的文件,一般我们不用管,只要不删就行。因为这些是程序安装、运行时需要用到的配置文件。但对开发者来说,这种文件是怎么回事就必须搞清了。本文从.cfg文件的创建、编辑修改到使用等方面,进行解读,帮助大家掌握配置文件。

一、配置文件的作用

配置文件的作用是保存一些在程序运行时需用到的参数,在程序运行过程中,通过代码读取配置文件获得参数,保障程序的正常运行。如果误删了配置文件,代码取不到数据,程序也就无法正常运行了。配置文件一般保存的参数有:

1)使用数据库的程序,程序与数据库的连接参数,常常被写入配置文件读取调用;

2)有登录账号、密码的程序,登录名及账号信息一般也会写入配置文件。当程序运行到登录界面时,只需读取配置文件,就能对登录信息进行判断,而不必运行到主程序,提高运行效率。

3)桌面程序界面设置信息等

这里需要注意的是,不是所有的程序都必须有配置文件。因为配置文件的作用说白了也就是单独存储数据,如果项目很小,用到的数据很少,就没有弄配置文件的必要, 直接把数据写在代码里就可以了。

二、配置文件的后缀格式

很多人奇怪为什么配置文件的后缀格式.cfg是什么意思,而有时.ini、.xml、.dat格式文件也叫配置文件?其实,知道了配置文件的本质和项目开发习惯就明白了。首先,配置文件的本质就是文本文件,能直接用记事本打开、编辑。文件的后缀,可以是.txt,也可以根据自己的意愿随便修改,比如改为.cfg,.ini等都是没问题的。

虽然配置文件的后缀可以根据自己的喜好随意定,但也不是任何时候想改就改的。因为配置文件的后缀格式已经写入到程序代码里了,如果中途修改后缀,而代码里还是原后缀格式,就会造成找不到配置文件导致程序运行不了的后果。比如,原配置文件为cg.cfg,一般代码里会有这样的读取语句:

cp.read('source\cg.cfg')

如果将配置文件修改为cg.ini,则须修改代码语句为:

cp.read('source\cg.ini')

否则,若还是cp.read('source\cg.cfg')语句,就找不到模配置文件,报错。而我们安装软件时,是不可能改代码的。所以,面对安装包里的配置文件,正确做法就是不管,不删不改不移动就行。

为提高代码的通用性和可读性,项目开发时会提前约定好固定的后缀作为配置文件的格式,这就是项目开发习惯的结果。所以现在一般只要看到.cfg、.ini等后缀的文件,就知道这是配置文件。若突然换了个个性的后缀,就容易让人蒙圈。

所以后缀.cfg没有特殊的含义,只是约定的习惯用法而已,只不过不止约定了这一种,还约定了.ini、.dat、.xml等,所以.ini、.xml、.dat格式文件都叫配置文件

三、配置文件里内容的格式

和文件后缀格式可以随便自定义不同,配置文件里内容的格式要求很严格,内容样式为:

[section]  

option = value

...

其中:section为节点,用中括号括起来;option为键,value为键对应的值,option= value构成键值对,一个键只对应一个值,同一个section节点下option键不能重复出现

如下图,节点(section)[rew]下出现了两个相同的键(option)name:

运行python读取该文件代码:cp.read('1.txt')时,会提示报错:

configparser.DuplicateOptionError: While reading from '1.txt' [line 3]: option 'name' in section 'rew' already exists

意思是第3行的option'name'在节点section‘rew’里已存在。

四、配置文件的创建、写入数据

了解了配置文件的本质是文本文件,且后缀可随意更改的特点后,文件的创建和修改就简单了。直接用记事本创建文件,按内容格式要求写好数据后,将文件保存为后缀为.cfg或其他拟定的后缀格式文件即可。也可以直接用代码方法:用open('confg.cfg', 'w')函数可以在当前文件夹下创建名为“confg.cfg”的文件,'w'参数代表可以向文件写入数据,然后用write(f),将文件保存下来。如下面的代码

from configparser import ConfigParser
cp = ConfigParser()
cp.add_section('test1')
cp.set('test1', 'name', '张三')
cp.set('test1', 'sn', '123456')
with open('confg.cfg', 'w') as f:
    cp.write(f)

运行后即生成的了保存有两条信息的confg.cfg文件,右键用记事本打开查看,结果为:

五、配置文件的常用操作函数

上面我们创建并写入了配置文件内容,有时,我们需要在程序运行过程中,根据用户交互信息,自动修改配置文件信息,这就只能用代码了。python的ConfigParser模块下有多个操作配置文件的函数,常用的有10个,具体如下:

1、read(file.cfg):读取配置文件

from configparser import ConfigParser
cp = ConfigParser()
cp.read('confg.cfg')

2、set(section, name, value):新增项目(name:“李四”,sn:‘123’),新增时,节点(section)下不能存在为‘李四’的项目键(name),否则就变成了修改键对应的值,如下面第3条

cp.set('test1', '李四', '123')

3、set(section, name, value):将配置文件里的“李四”对应sn修改为新sn“666”

cp.set('test1', '李四', '666')  # 将原sn:123,该为新sn:666

4、remove(section, name):删除项目

cp.remove_section('test2')  #如果文件里没有test2节点,就无法删除,会报错,所以一般要先判断是否存在该节点。

5、has_section(section):判断是否存在节点

cp.add_section('test2')

6、add_section(section):增加节点

cp.add_section('test2')

注意:不能增加已经存在的section,为了避免出错,可先判断是否存在节点(section)

7、sections():得到所有的section,返回结果为列表

from configparser import ConfigParser
cp = ConfigParser()
cp.add_section('test1')
cp.set('test1', 'name', '张三')
cp.set('test1', 'sn', '123456')
cp.add_section('test2')
cp.set('test2', 'name', '张')
cp.set('test2', 'sn', '123')
with open('confg.cfg', 'w') as f:
    cp.write(f)
cp.read('confg.cfg')
print(cp.sections())

运行结果为:['test1', 'test2']

8、options(section) :得到section下的所有option (key值),返回结果为列表

from configparser import ConfigParser
cp = ConfigParser()
cp.read('confg.cfg')
print(cp.options('test1'))

运行结果为:['name', 'sn']

9、items(section):得到section的所有键值对

from configparser import ConfigParser
cp = ConfigParser()
cp.read('confg.cfg')
print(cp.items('test1'))

运行结果为:[('name', '张三'), ('sn', '123456')]

10、get(section, option):得到section中option的值,返回为string类型

from configparser import ConfigParser
cp = ConfigParser()
cp.read('confg.cfg')
print(cp.get('test1', 'name'))

运行结果:张三

11、getint(section, option):得到section中的option值,返回为int类型

from configparser import ConfigParser
cp = ConfigParser()
cp.read('confg.cfg')
print(cp.getint('test1', 'sn'),type(cp.getint('test1', 'sn')))

运行结果:123456 <class 'int'>

6、试用

了解了这些后,我们可以试着找一些软件配置文件,打开看数据都是些什么格式。比如,下图是SQL SERVER安装包里带的一个配置文件的内容,注意该配置文件后缀是.ini,用记事本打开查看:

注意着里面的第一行是分号开头的字符串,在我们正常的python3,环境下读取时会报错,将分号改为python里的注释符即可。

异常错误处理

用ConfigParser模块的read函数读取配置文件时,偶尔会出现一种奇怪的错误,提示为

configparser.MissingSectionHeaderError:File contains no section headers,

具体是将配置文件的第一行读取为:'锘縖sql_connect]\n',而实际是'[sql_connect]'。

这种错误很无语,很让初次见到的人崩溃。其实,这种错误是因为windows读取配置文件时,额外追加了乱码信息导致。如何消除乱码,有人用字符替换,有人通过保存配置文件时修改编码方式,逐一试过后,都没起作用,看来不是特效药。最后,找到了一个最简单的办法,重建一个同名的文件,将配置文件里的内容复制粘贴过去就好。

相关文章

掌握这些Python后缀,让你的编程之路更加顺利

想象一下,你正在玩一个大型的多人在线游戏,你的任务是建造一个强大的城堡,保护自己免受敌人的攻击。你需要收集各种资源,比如木材、石头和金属,然后将它们组合在一起,建造出你的城堡。这就像是编程中的代码编写...

Python处理文件的6个常用代码,使用频率很高,值得收藏

日常工作中,我们经常会遇到一些查找、存储文件的问题,比如文件合并、文件分解等,这些问题涉及到对文件进行操作处理。对此,Python的OS库提供了很多功能模块供使用,本文整理了其中6个使用频率很高的常用...

Python语言的12个基础知识点小结(python语言基础总结)

python编程中常用的12种基础知识总结:正则表达式替换,遍历目录方法,列表按列排序、去重、字典排序、字典、列表、字符串互转,时间对象操作,命令行参数解析(getopt),print 格式化输出,进...

文件后缀,也称为文件扩展名,用于标识文件的类型

文件后缀,也称为文件扩展名,用于标识文件的类型,帮助操作系统确定使用何种程序来打开文件。这里列举一些常见的文件后缀名及其所代表的文件类型:? 文本文件:? .txt:纯文本文件? .doc、.docx...

「Python教程」第5篇 Python程序结构

Python程序的基本单元是文件,每个文件就是独立的一个最小的Python程序。用Python IDLE创建文件下面的动图显示了如何使用Python IDLE在Python安装目录下创建一个test....

破解文件处理难题:用 Python 处理 .txt 文件的必学方法

引言:Python中,对.txt后缀的文件进行多种操作。以下是一些常见的操作及其示例代码:先让我们来学习一下文件的打开模式及其作用:读取整个文件:path =r'D:\file.txt'...