圆月山庄资源网 Design By www.vgjia.com
一、ini文件介绍
INI文件格式是某些平台或软件上的配置文件的非正式标准,以节(section)和键(key)构成,常用于微软Windows操作系统中。这种配置文件的文件扩展名多为INI
二、ini文件的结构
- 片段[section]
- 键名 option
- 值 value
三、实例:
实例1
python25.ini
[teachers] name = ['yushen', 'pianpian'] age = 16 gender = '女' favor = {"movie": "追风", "music": "周杰伦"} [student] name = ['啦啦迷弟', '啦啦迷妹'] age = 18
操作ini文件
from configparser import ConfigParser # 初始化 config = ConfigParser() # 读取文件 config.read('python25.ini', encoding='utf-8') a = config.get('teachers', 'name') print(a) print(type(a))
运行结果如下:
实例2
fz.ini
读取fz.ini文件代码:
import configparser import os curpath = os.path.dirname(os.path.realpath(__file__)) cfgpath = os.path.join(curpath, "fz.ini") # fz.ini的路径 print(cfgpath) # 创建管理对象 conf = configparser.ConfigParser() # 读ini文件 conf.read(cfgpath, encoding="utf-8") # 获取所有的section sections = conf.sections() # 返回list print(sections) items = conf.items('oracle') # list里面对象是元祖 print(items)
运行结果:
实例3,封装升级
set修改,add添加,write写入、remove删除
此封装实现以下功能:
- 获取sections列表
- 获取指定的section的options列表
- 获取指定section的配置信息列表
- 按类型读取配置信息
- 新增section
- 设置指定option值
- 删除指定section
- 删除指定option
# -*- coding:utf-8 -*- from configparser import ConfigParser import os class TEINI: def __init__(self, path): self.path = path self.ini = ConfigParser() self.ini.read(self.path) # 获取sections列表 def get_sections(self): if self.ini: return self.ini.sections() # 获取指定的section的options列表 def get_options_by_section(self, section): if self.ini: return self.ini.options(section) # 获取指定section的配置信息列表 def get_section_items(self, section): if self.ini: return self.ini.items(section) # 按类型读取配置信息 # 返回字符串类型 def get_string(self, section, option): if self.ini: return self.ini.get(section, option) # 返回int类型 def get_int(self, section, option): if self.ini: return self.ini.getint(section, option) # 返回float类型 def get_float(self, section, option): if self.ini: return self.ini.getfloat(section, option) # 返回bool类型 def get_boolean(self, section, option): if self.ini: return self.ini.getboolean(section, option) # 新增section def add_section(self, section): if self.ini: self.ini.add_section(section) self.ini.write(open(self.path, "w")) # 设置指定option值 def set_option(self, section, option, value): if self.ini: self.ini.set(section, option, value) self.ini.write(open(self.path, "w")) # 删除指定section def remove_section(self, section): if self.ini: self.ini.remove_section(section) self.ini.write(open(self.path, "w")) # 删除指定option def remove_option(self, section, option): if self.ini: self.ini.remove_option(section, option) self.ini.write(open(self.path, "w")) if __name__ == "__main__": print("python ini标准库解析实例======根据需求运行代码!!!") # 如果存在mysql.ini先删除,方便下列代码的运行 if os.path.exists("mysql.ini"): os.remove("mysql.ini") # 我们先写一些数据到mysql.ini中 ini = TEINI("mysql.ini") # 先加一个mysql section mysql_section = "mysql" ini.add_section(mysql_section) # 在mysql section下写入一些配置信息 ini.set_option(mysql_section, "host", "192.168.3.1") ini.set_option(mysql_section, "port", "3306") ini.set_option(mysql_section, "db", "mysql") ini.set_option(mysql_section, "user", "admin") ini.set_option(mysql_section, "password", "111111") # 再添加一个oracle section oracle_section = "oracle" ini.add_section(oracle_section) # oracle section下写入一些配置信息 ini.set_option(oracle_section, "host", "192.172.0.1") ini.set_option(oracle_section, "port", "8080") ini.set_option(oracle_section, "db", "oracle") ini.set_option(oracle_section, "user", "guiyin") ini.set_option(oracle_section, "password", "666666") # 获取下所有的section,并在console输出 sections = ini.get_sections() print(sections) # 遍历各个section下的options,并在console中输出 print("===" * 20) for sec in sections: print(sec, " 中的options为: ") options = ini.get_options_by_section(sec) print(options) print("===" * 20) # 获取各个section下的配置信息 for sec in sections: print(sec, " 中的配置信息为: ") items = ini.get_section_items(sec) print(items) print("***" * 20) # 获取指定的option值这里演示读取host和port host = ini.get_string("mysql", "host") port = ini.get_int("mysql", "port") print("类型: ", type(host), " ", type(port)) print(host, " ", port) # 删除mysql中的host配置 ini.remove_option("mysql", "host") # 删除oracle section ini.remove_section("oracle") # 修改mysql port的值为4000 ini.set_option("mysql", "port", "5538") # 最终mysql.ini中的文件内容如下 # [mysql] # port = 5538 # db = mysql # user = admin # password = 111111 items = ini.get_section_items("mysql") print(items) print("!!!" * 20)
运行结果如下:
总结
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月02日
2024年11月02日
- 《暗喻幻想》顺风耳作用介绍
- 崔健1985-梦中的倾诉[再版][WAV+CUE]
- 黄子馨《追星Xin的恋人们2》HQ头版限量编号[WAV+CUE]
- 孟庭苇《情人的眼泪》开盘母带[低速原抓WAV+CUE]
- 孙露《谁为我停留HQCD》[低速原抓WAV+CUE][1.1G]
- 孙悦《时光音乐会》纯银CD[低速原抓WAV+CUE][1.1G]
- 任然《渐晚》[FLAC/分轨][72.32MB]
- 英雄联盟新英雄安蓓萨上线了吗 新英雄安蓓萨技能介绍
- 魔兽世界奥杜尔竞速赛什么时候开启 奥杜尔竞速赛开启时间介绍
- 无畏契约CGRS准星代码多少 CGRS准星代码分享一览
- 张靓颖.2012-倾听【少城时代】【WAV+CUE】
- 游鸿明.1999-五月的雪【大宇国际】【WAV+CUE】
- 曹方.2005-遇见我【钛友文化】【WAV+CUE】
- Unity6引擎上线:稳定性提升、CPU性能最高提升4倍
- 人皇Sky今日举行婚礼!电竞传奇步入新篇章