杰网资源 Design By www.escxy.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.escxy.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
杰网资源 Design By www.escxy.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。







