zoukankan      html  css  js  c++  java
  • Python模块学习

    配置文件

      很多软件都用到了配置文件,像git运行的时候会读取~/gitconfig,MySQL运行的时候会读取/etc/my.cnf,Python 提供的包管理工具pip命令,也会去读取~/.pip/pip.cnf文件。

      配置文件的好处是,配置成功后不需要每次使用时都指定相应的参数,而且,典型的ini格式的配置文件具有和编程语言无关、可读性强和易于处理等优点、已经被广泛使用。

      一个典型的配置文件包含一到多个章节(section),每个章节下包含一到多个选项(option)。下面是一个MySQL的配置文件:

    [client]
    port = 3306
    user = mysql
    password = mysql
    host = 127.0.0.1
    
    [mysqld]
    basedir = /usr/local/mysql
    datadir = /usr/local/mysql/data
    tmpdir = /tmp
    skip-external-locking
    

    ConfigParser模块

      Python中使用ConfigParser模块来解析配置文件。ConfigParser中包含一个ConfigParser类,一个ConfigParser对象可以同时解析多个配置文件,一般情况下我们只会使用ConfigParser模块解析一个文件文件。

      首先,解析一个配置文件,需要先创建一个ConfigParser对象,创建ConfigParser对象时有多个参数,其中比较重要的是allow_no_value,allow_no_value默认取值为False,表示在配置文件中是否允许有没有选项的值的情况。默认情况下每个选项都应该有一个值,但是在一些特殊的应用选项下,选项存在即为真,不存在即为假,比如上面MySQL的配置文件skip-external-locking。所以如果需要解析这样的参数,那么就需要在实例化的时候添加allow_no_value 为True

    >>> import ConfigParser
    >>> cp = ConfigParser.ConfigParser(allow_no_value=True)
    >>> 
    

      有了ConfigParser对象以后,我们就可以使用read方法,从配置文件中读取配置内容了。

    >>> cp.read('/etc/my.cnf')
    ['/etc/my.cnf']
    >>> 
    

    主要方法

    ConfigParser对象中有很多方法,其中与读取配置文件,判断配置相关的方法有:

    • sections:返回一个包含所有章节的列表
    • has_sections:判断章节是否存在
    • items:以元祖的形式返回所有的选项
    • options:返回一个包含章节下所有选项的列表
    • has_option:判读某个选项是否存在
    • get、getboolean、getinit、getfloat:获取选项的值

    下面以MySQL的配置文件my.cnf为例子

    >>> cp.sections()
    ['mysqld', 'mysqld_safe']
    
    >>> cp.has_section('mysqld')
    True
    
    >>> cp.has_section('client')
    False
    
    >>> cp.options('mysqld')
    ['datadir', 'socket', 'user', 'symbolic-links']
    
    >>> cp.has_option('mysqld','user') 
    True
    
    >>> cp.get('mysqld','user')
    'mysql'
    >>> 
    

    ConfigParser对象也提供了许多方法便于我们修改配置文件:

    • remove_section:删除一个章节
    • add_section:添加一个章节
    • remote_option:删除一个选项
    • set:添加一个选项
    • write:将ConfigParser对象中保存的数据保存的文件中去
    >>> cp.add_section('client')
    >>> cp.set('client','host','127.0.0.1')
    >>> cp.set('client','user','mysql')
    >>> cp.set('client','password','123456')
    >>> cp.write(open('/tmp/my.cnf','w'))
    >>> exit()
    [root@centos-linux python]# cd /tmp
    my.cnf 
    
    [root@centos-linux tmp]# cat my.cnf 
    [mysqld]
    datadir = /var/lib/mysql
    socket = /var/lib/mysql/mysql.sock
    user = mysql
    symbolic-links = 0
    
    [mysqld_safe]
    log-error = /var/log/mysqld.log
    pid-file = /var/run/mysqld/mysqld.pid
    
    [client]
    host = 127.0.0.1
    user = mysql
    password = 123456
    
    [root@centos-linux tmp]# 
    

      

  • 相关阅读:
    Linux下架构高可用性网络----HA+LB+lvs
    MacBook如何用Parallels Desktop安装windows7/8
    Win10如何彻底禁用小娜?彻底禁用小娜的方法
    安卓手机微信发不出去怎么办 微信不能发信息怎么办
    计算机名、主机名、用户账户名与NetBIOS名有什么区别
    安装corel x8提示你已安装了另外一个版本
    ssh整合问题总结--在添加商品模块实现图片(文件)的上传
    代理设计模式之静态代理与动态代理(超..)详解
    Java基础--反射机制的知识点梳理
    ssh整合问题总结--运行项目时报java.lang.StackOverflowError(堆栈溢出)异常
  • 原文地址:https://www.cnblogs.com/dachenzi/p/7968076.html
Copyright © 2011-2022 走看看