本文主要是介绍Python ConfigParser的使用与Pyhon编程规范,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1.基本的读取配置文件
-read(filename) 直接读取ini文件内容
-sections() 得到所有的section,并以列表的形式返回
-options(section) 得到该section的所有option
-items(section) 得到该section的所有键值对
-get(section,option) 得到section中option的值,返回为string类型
-getint(section,option) 得到section中option的值,返回为int类型,还有相应的getboolean()和getfloat() 函数。
2.基本的写入配置文件
-add_section(section) 添加一个新的section
-set( section, option, value) 对section中的option进行设置,需要调用write将内容写入配置文件。
3.基本例子
test.conf
- [sec_a]
- a_key1 = 20
- a_key2 = 10
- [sec_b]
- b_key1 = 121
- b_key2 = b_value2
- b_key3 = $r
- b_key4 = 127.0.0.1
parse_test_conf.py
- import ConfigParser
- cf = ConfigParser.ConfigParser()
- #read config
- cf.read("test.conf")
- # return all section
- secs = cf.sections()
- print 'sections:', secs
- opts = cf.options("sec_a")
- print 'options:', opts
- kvs = cf.items("sec_a")
- print 'sec_a:', kvs
- #read by type
- str_val = cf.get("sec_a", "a_key1")
- int_val = cf.getint("sec_a", "a_key2")
- print "value for sec_a's a_key1:", str_val
- print "value for sec_a's a_key2:", int_val
- #write config
- #update value
- cf.set("sec_b", "b_key3", "new-$r")
- #set a new value
- cf.set("sec_b", "b_newkey", "new-value")
- #create a new section
- cf.add_section('a_new_section')
- cf.set('a_new_section', 'new_key', 'new_value')
- #write back to configure file
- cf.write(open("test.conf", "w"))
得到终端输出:
sections: ['sec_b', 'sec_a']
options: ['a_key1', 'a_key2']
sec_a: [('a_key1', "i'm value"), ('a_key2', '22')]
value for sec_a's a_key1: i'm value
value for sec_a's a_key2: 22
更新后的test.conf
- [sec_b]
- b_newkey = new-value
- b_key4 = 127.0.0.1
- b_key1 = 121
- b_key2 = b_value2
- b_key3 = new-$r
- [sec_a]
- a_key1 = i'm value
- a_key2 = 22
- [a_new_section]
- new_key = new_value
4.Python的ConfigParser Module中定义了3个类对INI文件进行操作。分别是RawConfigParser、ConfigParser、SafeConfigParser。RawCnfigParser是最基础的INI文件读取类,ConfigParser、SafeConfigParser支持对%(value)s变量的解析。
设定配置文件test2.conf
- [portal]
- url = http://%(host)s:%(port)s/Portal
- host = localhost
- port = 8080
使用RawConfigParser:
- import ConfigParser
- cf = ConfigParser.RawConfigParser()
- print "use RawConfigParser() read"
- cf.read("test2.conf")
- print cf.get("portal", "url")
- print "use RawConfigParser() write"
- cf.set("portal", "url2", "%(host)s:%(port)s")
- print cf.get("portal", "url2")
得到终端输出:
use RawConfigParser() read
http://%(host)s:%(port)s/Portal
use RawConfigParser() write
%(host)s:%(port)s
改用ConfigParser:
- import ConfigParser
- cf = ConfigParser.ConfigParser()
- print "use ConfigParser() read"
- cf.read("test2.conf")
- print cf.get("portal", "url")
- print "use ConfigParser() write"
- cf.set("portal", "url2", "%(host)s:%(port)s")
- print cf.get("portal", "url2")
得到终端输出:
use ConfigParser() read
http://localhost:8080/Portal
use ConfigParser() write
localhost:8080
改用SafeConfigParser:
- import ConfigParser
- cf = ConfigParser.SafeConfigParser()
- print "use SafeConfigParser() read"
- cf.read("test2.conf")
- print cf.get("portal", "url")
- print "use SateConfigParser() write"
- cf.set("portal", "url2", "%(host)s:%(port)s")
- print cf.get("portal", "url2")
得到终端输出(效果同ConfigParser):
use SafeConfigParser() read
http://localhost:8080/Portal
use SateConfigParser() write
localhost:8080
==========================================
一、ConfigParser简介
ConfigParser 是用来读取配置文件的包。配置文件的格式如下:中括号“[ ]”内包含的为section。section 下面为类似于key-value 的配置内容。
2: db_host = 127.0.0.1
3: db_port = 22
4: db_user = root
5: db_pass = rootroot
6:
7: [concurrent]
8: thread = 10
9: processor = 20
中括号“[ ]”内包含的为section。紧接着section 为类似于key-value 的options 的配置内容。
二、ConfigParser 初始工作
使用ConfigParser 首选需要初始化实例,并读取配置文件:
2: cf.read( "配置文件名")
三、ConfigParser 常用方法
1. 获取所有sections。也就是将配置文件中所有“[ ]”读取到列表中:
2: print 'section:', s
将输出(以下将均以简介中配置文件为例):
2. 获取指定section 的options。即将配置文件某个section 内key 读取到列表中:
2: print 'options:', o
将输出:
3. 获取指定section 的配置信息。
2: print 'db:', v
将输出:
4. 按照类型读取指定section 的option 信息。
同样的还有getfloat、getboolean。
2: db_host = cf.get( "db", "db_host")
3: db_port = cf.getint( "db", "db_port")
4: db_user = cf.get( "db", "db_user")
5: db_pass = cf.get( "db", "db_pass")
6:
7: # 返回的是整型的
8: threads = cf.getint( "concurrent", "thread")
9: processors = cf.getint( "concurrent", "processor")
10:
11: print "db_host:", db_host
12: print "db_port:", db_port
13: print "db_user:", db_user
14: print "db_pass:", db_pass
15: print "thread:", threads
16: print "processor:", processors
将输出:
2: db_port: 22
3: db_user: root
4: db_pass: rootroot
5: thread: 10
6: processor: 20
5. 设置某个option 的值。(记得最后要写回)
2: cf.write(open( "test.conf", "w"))
6.添加一个section。(同样要写回)
2: cf.set('liuqing', 'int', '15')
3: cf.set('liuqing', 'bool', ' true')
4: cf.set('liuqing', 'float', '3.1415')
5: cf.set('liuqing', 'baz', 'fun')
6: cf.set('liuqing', 'bar', 'Python')
7: cf.set('liuqing', 'foo', '%(bar)s is %(baz)s!')
8: cf.write(open( "test.conf", "w"))
7. 移除section 或者option 。(只要进行了修改就要写回的哦)
2: cf.remove_section('liuqing')
3: cf.write(open( "test.conf", "w"))
点击(此处)折叠或打开
- #!/usr/bin/env python
- from ConfigParser import ConfigParser
- CONFIGFILE="f.txt"
- config=ConfigParser()
- config.read(CONFIGFILE)
- print config.get('messages','greeting')
- radius=input(config.get('messages','questions')+' ')
- print config.get('messages','result')
- print config.getfloat('numbers','pi')*radius**2
-
- s=config.sections()
- print'section: ',s
- o=config.options('messages')
- print'messages option: ',o
- v=config.items("messages")
- print'message de xinxi: ',v
-
- config.add_section('liuyang1')
- config.set('liuyang1','int','15')
- config.set('liuyang'1,'hhhh','hello world')
- config.write(open("f.txt","w"))
- print config.get('liuyang1','int')
- print config.get('liuyang1','hhhh')
-
-
-
-
-
- #!/usr/bin/env python
- import ConfigParser
- import sys
- config=ConfigParser.ConfigParser()
- config.add_section("book1")
- config.set("book1","title","hello world")
- config.set("book1","aut","log")
- config.write(open("f.txt","w"))
==========================================
1、变量不推荐使用的字符
不要用字符‘l’(小写字母l),‘O’(大写字母),或‘I’(大写字母)作为单字符的变量名。在某些字体中这些字符不能与数字1和0分辨。试着在使用‘l’时用‘L’代替。
2、局部变量
类型名+变量简写,并且从第二个单词开始,首字母大写。例如字符型的路名称
strWayName.
3、全局变量
g+类型名+变量简写,并且从第二个单词开始,首字母大写。例如字符型的路名称
gstrWayName.
4、包、模块的命名规则
全部以小写字母的形式来命名。模块名应该是不含下划线、简短、小写字母。
5、类、对象的命名规则
每个单词的首字母要大写,其他字母小写;
对象名用小写字母来表示;
类的私有属性、私有方法以两个下划线作为前缀,对象通过点操作符来访问类中的属性和方法。
6、函数的命名规则
函数名必须以下划线或字母开头,可以包含任意字母、数字或下划线的组合。
函数名是区分大小写的。
函数名不能是保留字。
建议第一个单词的首字母小写。
7、注释
1.单行注释
Python中的单行注释使用#号加若干空格开始,后面是注释的内容,以回车作为注释的结束。例如:
#声明并初始化变量num
num=1
2.行内注释
Python中的行内注释是最常用的,行内注释应该至少用两个空格和语句分开,它们以#号和单个空格开始。例如:
num=1 #声明并初始化变量num
3.注释块
注释块通常应用于跟随一些(或者全部)代码并和这些代码有着相同的缩进层次。注释块中也使用#号和一个空格开始。注释块内的段落以仅含单个#的行分隔。
Python一般会忽略#行的内容,跳过#行执行后面的内容。特殊含义的注释例外。Python还有一些特殊的注释,用以完成一些特别的功能,例如中文注释、程序的跨平台等。
1) 中文注释
如果需要在代码中使用中文注释,必须在Python文件的最前面加上如下注释说明:
#_*_ coding:UTF-8 _*_
2) 跨平台注释
如果需要使Python程序运行在Windows以外的平台上,则需要在Python文件的最前面加上如下注释说明:
!# /usr/bin/python
4、变量注释
所有变量建议先定义后使用,在定义时可以给变量赋空值,同时在后面给出注释;
建议一行只定义一个变量。
5、函数注释
函数名称:函数名
功能描述:函数功能描述
输入参数:
输入参数名称1:输入参数的类型及其代表的含义
输入参数名称2:输入参数的类型及其代表的含义
输出参数:
输出参数名称1:输出参数的类型及其代表的含义
输出参数名称2:输出参数的类型及其代表的含义
返回值:
返回值的类型,每种返回值所代表的含义,例如成功、失败、错误码。
6、类注释
类名称:类名称
功能描述:对该类的功能的描述
8、代码布局
1、缩进
4个空格一个缩进层次,不建议使用制表符(TAB)。
2、行的最大长度
所有行限制在最大79字符(Emacs准确得将行限制为长80字符),对顺序排放的大块文本(文档字符串或注释),推荐将长度限制在72字符。
3、空行
用两行空行分割顶层函数和类的定义;
类内方法(以及普通方法)的定义用单个空行分割;
在‘class’行和第一个方法定义之间也要有一个空行。
4、导入
通常应该在单独的行中导入(Imports),例如:
错误的做法:import sys, os
正确的做法:
import sys
import os
但是这样也是可以的:
from types import StringType, ListType
Imports 通常被放置在文件的顶部,仅在模块注释和文档字符串之后,在模块的全局变量和常量之前。Imports应该有顺序地成组安放:
1、标准库的导入(Imports )
2、相关的主包(major package)的导入(即,所有的email包在随后导入)
3、特定应用的导入(imports)
在每组导入之间放置一个空行,对于内部包的导入是不推荐使用相对导入的,对所有导入都要使用包的绝对路径。
从一个包含类的模块中导入类时,通常可以写成这样:
from MyClass import MyClass
from foo.bar.YourClass import YourClass
如果这样写导致了本地名字冲突,那么就这样写
import MyClass
import foo.bar.YourClass
即使用"MyClass.MyClass"和"foo.bar.YourClass.YourClass"
5、表达式和语句中的空格
1)、不需要空格的地方
紧挨着圆括号,方括号和花括号的地方如:"spam( ham[ 1 ],{ eggs:2 } )"。要始终将它写成"spam(ham[1],{eggs: 2})";
紧贴着函数调用的参数列表前开式括号(open parenthesis )的,如"spam (1)"。要始终将它写成"spam(1)";
紧贴在索引或切片,开始的开式括号前的,如:
"dict ['key'] = list [index]"。要始终将它写成"dict['key'] = list[index]"。
2)、需要空格的地方
紧贴在逗号,分号或冒号前的,如:
"if x == 4:print x,y:x,y = y,x"。要始终将它写成
"if x == 4:print x,y:x,y = y,x";
赋值(或其它)运算符周围的用于和其它并排的一个以上的空格,如:
x = 1。
########################################
1,*args和**kwargs是什么?
*args表示任何多个无名参数,它是一个tuple(元组);**kwargs表示关键字参数,它是一个dict(字典)。并且同时使用*args和**kwargs时,必须*args参数列要在**kwargs前,否则会提示语法错误“SyntaxError: non-keyword arg after keyword arg”。
2,含有单个元素的元组,必须在第一个(唯一一个)项目后跟一个逗号,这样Python程序才能区分元组和表达式中一个带圆括号的对象。
3,使用import..as语法。这是一种便利方法,以便于我们可以使用更短的模块名称,例如:import cPickle as p,把cPickle模块以p模块命名
4,Python的一些特殊方法:
__init__(self,...) 这个方法在新建对象恰好要被返回使用之前被调用。
__del__(self) 恰好在对象要被删除之前调用。
__str__(self) 在我们对对象使用print语句或是使用str()的时候调用。
__lt__(self,other) 当使用 小于 运算符(<)的时候调用。类似地,对于所有的运算符(+,>等等)都有特殊的方法。
__getitem__(self,key) 使用x[key]索引操作符的时候调用。
__len__(self) 对序列对象使用内建的len()函数的时候调用。
5,引用某个.py文件的类或者函数的方法:
若在同一个目录下,可以引用某个.py文件的类或函数
如果要引用的.py文件不在同一目录,则应指定路径,具体做法为:
import sys
sys.path.append('路径')
6,异常相关
try:
except Exception,e: 标注:except Exception,e 将异常赋值给e
7,\t 指的是一个Tab字符
8,在Python中调用MongoDB代码(本地):
import pymongo
connection=pymongo.Connection('127.0.0.1',27017)
db=connection.mydb 标注:mydb为你要调用的数据库名称
l=db.excel.find() 标注:以下三行,为我在数据库中建立的一个表,输出表项
for i in l:
print i
9,parseString,解释:字符串分解,把一个长字符串分解成若干小的字符串
10,xml.sax,解释:SAX(simple API for XML)是一种XML解析的替代方法。相比于DOM,SAX是一种速度更快,更有效的方法。它逐行扫描文档,一边扫描一边解析。而且相比于DOM,SAX可以在解析文档的任意时刻停止解析,但任何事物都有其相反的一面,对于SAX来说就是操作复杂。
这篇关于Python ConfigParser的使用与Pyhon编程规范的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!