Python3 配置文件(configparser)(转载)

本文由 Luzhuo 编写,转发请保留该信息. 
原文: http://blog.csdn.net/rozol/article/details/72793304

 

以下代码以Python3.6.1为例 
Less is more! 
configparser 可以读写和解析注释文件, 但是没有写入注释的功能

  1 #!/usr/bin/env python
  2 # coding=utf-8
  3 __author__ = 'Luzhuo'
  4 __date__ = '2017/5/26'
  5 # config_configparser.py 配置文件
  6 # configparser 可以读写和解析注释文件, 但是没有写入注释的功能
  7 
  8 import configparser
  9 import re
 10 
 11 
 12 config_str = '''
 13 # 配置文件信息案例
 14 [DEFAULT]
 15 minSdkVersion = 15
 16 targetSdkVersion = 24
 17 versionName = 1.0.0
 18 server action = yes
 19 
 20 [luzhuo.me]
 21 user = luzhuo
 22 
 23 # This is a comments.
 24 [mysql]
 25 ip = 127.0.0.1
 26 port = 3306
 27 '''
 28 
 29 def config_write():
 30     '''
 31     生成配置文件, 字典的形式添加数据
 32     '''
 33 
 34     config = configparser.ConfigParser()
 35 
 36     config['DEFAULT'] = {'minSdkVersion': '15',
 37                          'targetSdkVersion': '24',
 38                          'versionName': '1.0.0',
 39                          'server action': 'yes'}
 40 
 41     config['luzhuo.me'] = {}
 42     config['luzhuo.me']['user'] = 'luzhuo'
 43 
 44     config['mysql'] = {}
 45     topsecret = config['mysql']
 46     topsecret['ip'] = '127.0.0.1'
 47     topsecret['port'] = '3306'
 48 
 49     with open('config.ini', 'w') as configfile:
 50         config.write(configfile)
 51 
 52 
 53 def config_read():
 54     '''
 55     解析配置文件
 56     '''
 57 
 58     # 读取
 59     config = configparser.ConfigParser()
 60     config.read('config.ini')
 61 
 62     lists_header = config.sections()  # 配置组名, ['luzhuo.me', 'mysql'] # 不含'DEFAULT'
 63     print(lists_header)
 64 
 65     boolean = 'luzhuo.me' in config  # 配置组是否存在
 66     boolean = config.has_section("luzhuo.me")
 67     print(boolean)
 68 
 69     user = config['luzhuo.me']['user']
 70     print(user)
 71     mysql = config['mysql']
 72     mysql_ip = mysql['ip']
 73     mysql_port = mysql['port']
 74     print(mysql_ip, ":", mysql_port)
 75 
 76     for key in config['luzhuo.me']:  # 遍历配置组的key, 与'DEFAULT'组的key
 77         print(key)
 78 
 79     # 删除
 80     sec = config.remove_section("luzhuo.me")  # 删除
 81     config.write(open("config.ini", "w"))  # 写回去
 82 
 83     # 添加
 84     config.add_section("web.server")
 85     config.write(open("config.ini", "w"))
 86 
 87     # 修改/添加
 88     config.set("web.server", "http", "http://luzhuo.me")
 89     config.write(open("config.ini", "w"))
 90 
 91     # 删除key
 92     config.remove_option("mysql", "ip")
 93     config.write(open("config.ini", "w"))
 94 
 95 
 96 def config_func():
 97     '''
 98     写入的值均为字符串
 99     配合文件的节名称区分大小写, 键不区分大小写(可任意缩进), 注释用'#'和';'(用作整行前缀,可缩进,不推荐行内注释), 值可以跨越多行(要缩进,慎用), 键值分隔符'='和':'
100     DEFAULT无法移除,试图删除将引发ValueError, clear()保持原样, popitem()不返回
101     '''
102 
103     # --- ConfigParser 对象 ---
104     # 配置解析器, defaults:DEFAULT字典, dict_type:字典类型(默认:有序字典), allow_no_value:True是否接收不带值的选项(值为None),(默认False), delimiters:键值分隔符, comment_prefixes:整行注释符, inline_comment_prefixes:行内注释符(值之后), strict:是否去重:True(默认), empty_lines_in_values:值是否可以多行;(默认True),False(行标记选项的结尾), default_section:默认节的名称'DEFAULT', interpolation:插值, converters:转换器{类型转换器的名称, 从字符串转换所需数据的类型}{'dicimal': decimal.Decimal}
105     # class configparser.ConfigParser(defaults=None, dict_type=collections.OrderedDict, allow_no_value=False, delimiters=('=', ':'), comment_prefixes=('#', ';'), inline_comment_prefixes=None, strict=True, empty_lines_in_values=True, default_section=configparser.DEFAULTSECT, interpolation=BasicInterpolation(), converters={})
106     config = configparser.ConfigParser()
107 
108     # items(raw=False, vars=None)  # 所有节(含DEFAULT) ItemsView(section_name, section_proxy)(可遍历对象)
109     ItemsView = config.items()
110     dicts = config.defaults()  # DEFAULT字典
111     lists = config.sections()  # 可用的节列表(不含DEFAULT)
112     # has_section(section)  # 是否存在该节
113     boolean = config.has_section("mysql")
114     lists = config.options("mysql")  # 指定节的选项列表(含DEFAULT)
115     boolean = config.has_option("mysql", "ip")  # 是否存在指定节的选项
116 
117     # read(filenames, encoding=None)  # 尝试读取和解析文件名列表(不存在则忽略), 加载初始值调用read_file()要在read()之前调用
118     config.read("config.ini", encoding="utf-8-sig")  # windows下用记事本保存utf8格式要用utf-8-sig编码集
119     # read_file(f, source=None)  # 从f读取和解析配置数据, source:文件名
120     config.read_file(open('config.ini', encoding="utf-8-sig"))
121     # read_string(string, source='<string>')  # 从字符串解析配置数据
122     config.read_string(config_str)
123     # read_dict(dictionary, source='<dict>')  # 读取字典
124     config.read_dict({'section1': {'key1': 'value1',
125                                    'key2': 'value2'},
126                       'section2': {'key3': 'value3',
127                                    'key4': 'value4'}
128     })
129 
130     # get(section, option, *, raw=False, vars=None[, fallback])  # 获取指定节的选项值, fallback:为找到选项时的返回值
131     data_str = config.get("mysql", "ip", fallback=None)
132     # getint(section, option, *, raw=False, vars=None[, fallback])  #  获取整数(选项的值强转为整数)
133     data_int = config.getint("mysql", "port", fallback=-1)
134     # getfloat(section, option, *, raw=False, vars=None[, fallback])
135     data = float = config.getfloat("mysql", "port", fallback=-1)
136     # getboolean(section, option, *, raw=False, vars=None[, fallback])
137     data_bool = config.getboolean("DEFAULT", "server action", fallback=False)  # 获取布尔值,不区分大小写,识别'yes'/'no','on'/'off','true'/'false','1'/'0'
138 
139     # write(fileobject, space_around_delimiters=True)  # 将配置写入文件, space_around_delimiters:是否用空格分隔键值之间
140     config.write(open("config.ini", "w", encoding="utf-8"))
141     # add_section(section)  # 添加节, 节重复DuplicateSectionError, 与默认节重复ValueError, 不是字符串TypeError
142     config.add_section("server.luzhuo.me")
143     # remove_section(section) # 删除节, 存在True,不存在False
144     boolean = config.remove_section("server.luzhuo.me")
145     # set(section, option, value)  # 给指定的节设置值, 节不存在NoSectionError, option和value:选项和值为字符串,否则TypeError
146     config.set("server.luzhuo.me", "ip", "127.0.0.1")
147     # remove_option(section, option)  # 删除选型, 不存在节NoSectionError, 选项存在True,不存在False
148     boolean = config.remove_option("server.luzhuo.me", "ip")
149 
150     # optionxform(option)  # 子类重写该方法, 或 config.optionxform = str(str区分大小写) 修改, 用于选项名称转为在内部结构中使用的实现
151 
152     configparser.MAX_INTERPOLATION_DEPTH  # 使用默认插值时,  当raw=false,get()递归插值的最大深度
153 
154     config.clear()  # 所有节都包含'DEFAULT'值,对节的清空不会删除'DEFAULT'值
155     config.BOOLEAN_STATES.update({'enabled': True, 'disabled': False})  # 自定义boolean的判断
156     config.SECTCRE = re.compile(r"\[ *(?P<header>[^]]+?) *\]")  # 自定义节头的编译与解析的正则表达式(去除左右空格)
157 
158 
159 
160     # --- 异常 ---
161     try: pass
162     except configparser.Error: pass  # configparser异常的基类
163     except configparser.NoSectionError: pass  # 未找到指定节
164     except configparser.DuplicateSectionError: pass  # 节重复
165     except configparser.DuplicateOptionError: pass  # 选项重复
166     except configparser.NoOptionError: pass  # 未找到指定选项
167     except configparser.InterpolationError: pass  # 插值异常的基类
168     except configparser.InterpolationDepthError: pass  # 迭代次数超过MAX_INTERPOLATION_DEPTH
169     except configparser.InterpolationMissingOptionError: pass  # 选项不存在
170     except configparser.InterpolationSyntaxError: pass  # 替换源文本不符合语法
171     except configparser.MissingSectionHeaderError: pass  # 没有节头
172     except configparser.ParsingError: pass  # 解析文件错误
173 
174 
175 
176 if __name__ == "__main__":
177     config_write()
178     config_read()
179 
180     # config_func()

 

转载于:https://www.cnblogs.com/dion-90/p/7978081.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/252770.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

激光摄像机的原理及应用

近年来&#xff0c;在安防监控领域&#xff0c;以目前视频监控技术的发展情况&#xff0c;室内监控和白天正常环境下的监控已不是难题&#xff0c;但社会环境的发展日新月异&#xff0c;城市的发展、森林资源的不断流失、大型项目的建设、边防安全的守护等&#xff0c;这些环境…

Object.defineProperty 详解

最近想了解一下Vue是怎么实现数据双向绑定的&#xff0c;了解到是基于Object.definProperty,在此记录一下。 Object.defineProperty  顾名思义&#xff0c;就是给对象定义一个属性&#xff0c;总共有这么几种&#xff1a; value  属性的值writable  是否可改写&#xff0…

Java 实现排序

public class Sort {public static void main(String[] args) {int data[] {43,54,123,5,98,10,7,74,5,54};System.out.println("原先数组&#xff1a;");for(int d : data) {System.out.print(d " ");}System.out.println("\n");/*System.ou…

相机帧率和曝光时间的关系

文章转载自&#xff1a;http://blog.163.com/pluto_918/blog/static/203853902012111255634175/ 工业相机参数之帧率相关知识详解&#xff1a; 工业相机是机器视觉系统的重要组成部分之一&#xff0c;在机器视觉系统中有着非常重要的作用。工业相机已经被广泛应用于工业生产线…

班长的选举

/* Note:Your choice is C IDE */ #include "stdio.h" #include "string.h" void main() {int zs,ls,ww,zl;//定义一个给参选人员的票数int max;//int xuhao;//char name[5];//参选人员的名字zslswwzl0;//初始票数都为0printf("候选人名单如下\n"…

jquery刷新页面

window.location.reload()刷新当前页面. parent.location.reload()刷新父亲对象&#xff08;用于框架&#xff09; opener.location.reload()刷新父窗口对象&#xff08;用于单开窗口&#xff09; top.location.reload()刷新最顶端对象&#xff08;用于多开窗口&#xff09; 转…

Python 常量

总结&#xff1a;在Python中实际中没有严格的常量&#xff1b;知识程序员中约定俗成用变量名全部大写代表常量 常量的定义&#xff1a; 常量即指不变的量&#xff0c;如pai 3.141592653..., 或在程序运行过程中不会改变的量 举例&#xff0c;假如老男孩老师的年龄会变&#xff…

SlickOne 敏捷开发框架介绍(二) -- 多用户/多租户/SAAS软件基础框架实现

前言&#xff1a;在应用于集团版客户或SAAS平台服务的业务系统中&#xff0c;流程管理系统需要支持多用户组织模型。其中包括角色数据、流程定义数据和流程实例数据的多用户标识绑定。本文旨在全面描述如何基于SlickOne敏捷开发框架实现上述基础服务功能&#xff0c;形成一个完…

工业相机行曝光与全局曝光

工业相机行曝光与全局曝光 逐行曝光&#xff1a; 图1 逐行曝光模式 逐行曝光sensor 实现如图1逐行曝光模式所示。与全局曝光不同&#xff0c;逐行曝光从第一行开始曝光&#xff0c;一个行周期之后第二行才开始曝光。依次类推&#xff0c;经过N-1 行后第N 行开始曝光。第一行曝光…

【Alpha阶段汇总】成果展示与体验总结

一、燃尽图 二、软件截图 三、代码与图片、音乐素材仓库 git仓库 四、问题与总结 1.git提交问题 之前创建的仓库地址是http://git.oschina.net/8265559926/groupnet14 但是无论怎么输入都说找不到仓库 经反复思考&#xff0c;感觉可能是因为地址不是纯字母的原因。就重新注册了…

Accusoft结构化工具包FormSuite for Structured Forms常见问题解答(二)

FormSuite for Structured Forms是结构化的表单处理SDK和字符识别工具套包&#xff0c;包括表单处理工具FormFix和字符识别工具SmartZone。所有表格处理控件被设计为可以通过内存到内存的数据传输模式进行相互沟通。本文收集了一些FormSuite for Structured Forms常见问题及解答…

构建之法阅读笔记二

构建之法阅读笔记之二&#xff08;4-11章节&#xff09; 在这之前我不注重代码的规范性&#xff0c;也不是很注重代码风格的规范&#xff0c;也没有对自己写的代码进行审查的过程 根据书中所讲的这样写即使是自己的能力很强&#xff0c;写的代码只有自己可以看懂&#xff0c;别…

SVAC国家标准介绍

[摘要] 标准给人的感觉既熟悉又陌生;说熟悉&#xff0c;每天都会听到这个名词;从食品卫生到高科技&#xff0c;好像都离不开;说陌生&#xff0c;标准的数量以万计&#xff0c;包罗万象&#xff0c;其内容和目标鲜为人知。以SVAC标准来说&#xff0c;粗看内容和H.264等标准和差不…

JDBC批量操作性能提升

JDBC当使用INSERT INTO....VALUES()语句批量插入的时候&#xff0c;应该使用JDBC的PreparedStatement的批量操作方法&#xff0c;而不是採用一条一条运行的方法。比如&#xff08;来源&#xff1a;http://superjavason.iteye.com/blog/255423&#xff09;&#xff1a;如上图&am…

python学习笔记第9天《文件的管理办法》

1&#xff0c;文件路径&#xff1a; 绝对路径&#xff1a;d:\programfiles\python3.exe 即从根目录开始一直向下找到的文件 相对路径&#xff1a;从当前文件路径开始的路径名称2&#xff0c;编码方式&#xff1a;utf-8,gbk,unicode等等 文件是用什么格式写…

SVAC 2.0安全系统组成

SVAC2.0标准的一个很主要的特点就是视频安全和加密认证相比SVAC1.0更加规范&#xff0c;在视频安全方面更加重视。 通过信源层面的加密技术&#xff0c;实现端到端视频数据加密&#xff0c;构建更强大、更完整的视频安全体系。基于SVAC 2.0标准研究建立的安全系统&#xff08;…

【MySQL】(4)操作数据表中的记录

1. 插入记录INSERT 方法一&#xff1a; INSERT [INTO] tbl_name [(clo_name,...)] {VALUES | VALUE} ({expr | DEFAULT},...),(...),...; 比如&#xff1a; CREATE TABLE users( id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT, username VARCHAR(20) NOT NULL, password VA…

【技术知识】SVAC 2.0安全技术浅析

2017-09-26 08:52 加密可以有效保护数据的机密性&#xff0c;防止非授权访问和非法监听。签名可以识别视音频的产生源以及所对应的视音频数据是否完整或被篡改。SVAC 2.0标准规定了加密和签名接口及数据格式&#xff0c;支持对数据的安全保护&#xff0c;以统一的语法格式支持…

别再管你的API叫微服务了

你有没有听过这句名言&#xff1a;“计算机科学领域只有两个难题&#xff0c;缓存失效和命名”&#xff1f;据说这句话是Phil Karlton在1996年或1997年左右说的。围绕这句格言确实出现了很多带有喜剧色彩的说法&#xff0c;它们也提到了其他的一些问题&#xff0c;但最近我对AP…

第一篇JavaScript基础

1.什么是JavaScript 2.核心语法&#xff0c;变量 先声明&#xff0c;再赋值 var i;i0; 同时声明并赋值变量 var x,y,z0; 不声明直接赋值u2&#xff08;变量可以不经过声明直接赋值&#xff0c;但是容易出错&#xff0c;这种方法不建议采纳&#xff09;3. 3.核心语法&#xff0…