Python ConfigParser的使用与Pyhon编程规范

2024-04-04 13:38

本文主要是介绍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

  1. [sec_a] 
  2. a_key1 = 20 
  3. a_key2 = 10 
  4.   
  5. [sec_b] 
  6. b_key1 = 121 
  7. b_key2 = b_value2 
  8. b_key3 = $r 
  9. b_key4 = 127.0.0.1 

parse_test_conf.py

  1. import ConfigParser 
  2.   
  3. cf = ConfigParser.ConfigParser() 
  4.   
  5. #read config
  6. cf.read("test.conf"
  7.   
  8. # return all section
  9. secs = cf.sections() 
  10. print 'sections:', secs 
  11.   
  12. opts = cf.options("sec_a"
  13. print 'options:', opts 
  14.   
  15. kvs = cf.items("sec_a"
  16. print 'sec_a:', kvs 
  17.   
  18. #read by type
  19. str_val = cf.get("sec_a""a_key1"
  20. int_val = cf.getint("sec_a""a_key2"
  21.   
  22. print "value for sec_a's a_key1:", str_val 
  23. print "value for sec_a's a_key2:", int_val 
  24.   
  25. #write config
  26. #update value
  27. cf.set("sec_b""b_key3""new-$r"
  28. #set a new value
  29. cf.set("sec_b""b_newkey""new-value"
  30. #create a new section
  31. cf.add_section('a_new_section'
  32. cf.set('a_new_section''new_key''new_value'
  33.   
  34. #write back to configure file
  35. 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

  1. [sec_b] 
  2. b_newkey = new-value 
  3. b_key4 = 127.0.0.1 
  4. b_key1 = 121 
  5. b_key2 = b_value2 
  6. b_key3 = new-$r 
  7.   
  8. [sec_a] 
  9. a_key1 = i'm value 
  10. a_key2 = 22 
  11.   
  12. [a_new_section] 
  13. new_key = new_value 


4.Python的ConfigParser Module中定义了3个类对INI文件进行操作。分别是RawConfigParser、ConfigParser、SafeConfigParser。RawCnfigParser是最基础的INI文件读取类,ConfigParser、SafeConfigParser支持对%(value)s变量的解析。 
 
设定配置文件test2.conf

  1. [portal] 
  2. url = http://%(host)s:%(port)s/Portal 
  3. host = localhost 
  4. port = 8080 


使用RawConfigParser:

  1. import ConfigParser 
  2.  
  3. cf = ConfigParser.RawConfigParser() 
  4.  
  5. print "use RawConfigParser() read"
  6. cf.read("test2.conf"
  7. print cf.get("portal""url"
  8.  
  9. print "use RawConfigParser() write"
  10. cf.set("portal""url2""%(host)s:%(port)s"
  11. print cf.get("portal""url2"


得到终端输出:
use RawConfigParser() read 
http://%(host)s:%(port)s/Portal 
use RawConfigParser() write 
%(host)s:%(port)s

改用ConfigParser:

  1. import ConfigParser 
  2.  
  3. cf = ConfigParser.ConfigParser() 
  4.  
  5. print "use ConfigParser() read"
  6. cf.read("test2.conf"
  7. print cf.get("portal""url"
  8.  
  9. print "use ConfigParser() write"
  10. cf.set("portal""url2""%(host)s:%(port)s"
  11. print cf.get("portal""url2"


得到终端输出:
use ConfigParser() read 
http://localhost:8080/Portal 
use ConfigParser() write 
localhost:8080

改用SafeConfigParser:

  1. import ConfigParser 
  2.  
  3. cf = ConfigParser.SafeConfigParser() 
  4.  
  5. print "use SafeConfigParser() read"
  6. cf.read("test2.conf"
  7. print cf.get("portal""url"
  8.  
  9. print "use SateConfigParser() write"
  10. cf.set("portal""url2""%(host)s:%(port)s"
  11. print cf.get("portal""url2"


得到终端输出(效果同ConfigParser):
use SafeConfigParser() read 
http://localhost:8080/Portal 
use SateConfigParser() write 
localhost:8080 

http://www.linuxso.com/linuxbiancheng/8987.html

==========================================

一、ConfigParser简介

ConfigParser 是用来读取配置文件的包。配置文件的格式如下:中括号“[ ]”内包含的为section。section 下面为类似于key-value 的配置内容。

1: [db]

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 首选需要初始化实例,并读取配置文件:

1: cf = ConfigParser.ConfigParser()

2: cf.read( "配置文件名")

 

三、ConfigParser 常用方法

1. 获取所有sections。也就是将配置文件中所有“[ ]”读取到列表中:

1: s = cf.sections()

2: print 'section:', s

将输出(以下将均以简介中配置文件为例):

1: section: ['db', 'concurrent']

2. 获取指定section 的options。即将配置文件某个section 内key 读取到列表中:

1: o = cf.options( "db")

2: print 'options:', o

将输出:

1: options: ['db_host', 'db_port', 'db_user', 'db_pass']

3. 获取指定section 的配置信息

1: v = cf.items( "db")

2: print 'db:', v

将输出:

1: db: [('db_host', '127.0.0.1'), ('db_port', '22'), ('db_user', 'root'), ('db_pass', 'rootroot')]

4. 按照类型读取指定section 的option 信息

同样的还有getfloat、getboolean。

1: #可以按照类型读取出来

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

将输出:

1: db_host: 127.0.0.1

2: db_port: 22

3: db_user: root

4: db_pass: rootroot

5: thread: 10

6: processor: 20

5. 设置某个option 的值。(记得最后要写回)

1: cf.set( "db""db_pass""zhaowei")

2: cf.write(open( "test.conf""w"))

6.添加一个section。(同样要写回)

1: cf.add_section('liuqing')

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 。(只要进行了修改就要写回的哦)

1: cf.remove_option('liuqing','int')

2: cf.remove_section('liuqing')

3: cf.write(open( "test.conf""w"))

点击(此处)折叠或打开

  1. #!/usr/bin/env python
  2. from ConfigParser import ConfigParser
  3. CONFIGFILE="f.txt"
  4. config=ConfigParser()
  5. config.read(CONFIGFILE)
  6. print config.get('messages','greeting')
  7. radius=input(config.get('messages','questions')+' ')
  8. print config.get('messages','result')
  9. print config.getfloat('numbers','pi')*radius**2

  10. s=config.sections()
  11. print'section: ',s
  12. o=config.options('messages')
  13. print'messages option: ',o
  14. v=config.items("messages")
  15. print'message de xinxi: ',v

  16. config.add_section('liuyang1')
  17. config.set('liuyang1','int','15')
  18. config.set('liuyang'1,'hhhh','hello world')
  19. config.write(open("f.txt","w"))
  20. print config.get('liuyang1','int')
  21. print config.get('liuyang1','hhhh')





  22. #!/usr/bin/env python
  23. import ConfigParser
  24. import sys
  25. config=ConfigParser.ConfigParser()
  26. config.add_section("book1")
  27. config.set("book1","title","hello world")
  28. config.set("book1","aut","log")
  29. 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编程规范的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/875929

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

一文深入详解Python的secrets模块

《一文深入详解Python的secrets模块》在构建涉及用户身份认证、权限管理、加密通信等系统时,开发者最不能忽视的一个问题就是“安全性”,Python在3.6版本中引入了专门面向安全用途的secr... 目录引言一、背景与动机:为什么需要 secrets 模块?二、secrets 模块的核心功能1. 基

python常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Python虚拟环境与Conda使用指南分享

《Python虚拟环境与Conda使用指南分享》:本文主要介绍Python虚拟环境与Conda使用指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python 虚拟环境概述1.1 什么是虚拟环境1.2 为什么需要虚拟环境二、Python 内置的虚拟环境工具

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删