ホームページ > バックエンド開発 > Python チュートリアル > PythonのConfigParser設定ファイルの詳しい説明

PythonのConfigParser設定ファイルの詳しい説明

巴扎黑
リリース: 2017-09-04 13:57:12
オリジナル
1725 人が閲覧しました

1. 基本的な読み取り設定ファイル

-read(filename)は、iniファイルcontent

-sections()を直接読み取り、すべてのセクションを取得し、リストの形式で返します

-options(section)セクションを取得します すべてのオプション

-items(section) セクションのすべてのキーと値のペアを取得します

-get(section,option) セクション内のオプションの値を取得し、文字列として返されます type

-getint( Section,option) セクションを取得します。 option の値は int 型で返され、対応する getboolean() および getfloat() 関数があります。

2. 基本的な設定ファイルの書き込み

-add_section(section) 新しいセクションを追加します

-set(section, option, value) セクション内のオプションを設定するには、write を呼び出してコンテンツ設定を書き込む必要がありますファイル。

3. 基本的な例

test.conf

[sec_a] 
a_key1 = 20 
a_key2 = 10 
  
[sec_b] 
b_key1 = 121 
b_key2 = b_value2 
b_key3 = $r 
b_key4 = 127.0.0.1
ログイン後にコピー

parse_test_conf.py

import ConfigParser 
cf = ConfigParser.ConfigParser() 
#read config 
cf.read("test.conf") 
# return all section 
secs = cf.sections() 
print 'sections:', secs 
  
opts = cf.options("sec_a") 
print 'options:', opts 
  
kvs = cf.items("sec_a") 
print 'sec_a:', kvs 
  
#read by type 
str_val = cf.get("sec_a", "a_key1") 
int_val = cf.getint("sec_a", "a_key2") 
  
print "value for sec_a's a_key1:", str_val 
print "value for sec_a's a_key2:", int_val 
  
#write config 
#update value 
cf.set("sec_b", "b_key3", "new-$r") 
#set a new value 
cf.set("sec_b", "b_newkey", "new-value") 
#create a new section 
cf.add_section('a_new_section') 
cf.set('a_new_section', 'new_key', 'new_value') 
  
#write back to configure file 
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
ログイン後にコピー

Updated test.conf

[sec_b] 
b_newkey = new-value 
b_key4 = 127.0.0.1 
b_key1 = 121 
b_key2 = b_value2 
b_key3 = new-$r 
  
[sec_a] 
a_key1 = i'm value 
a_key2 = 22 
  
[a_new_section] 
new_key = new_value
ログイン後にコピー

4. PythonのConfigParserモジュールクラスで定義されているものは3つあります。にINI ファイル。それぞれ、RawConfigParser、ConfigParser、SafeConfigParser です。 RawCnfigParser は、最も基本的な INI ファイル読み取りクラスであり、ConfigParser と SafeConfigParser は %(value)s 変数の解析をサポートします。

設定ファイル test2.conf を設定します

[portal] 
url = http://%(host)s:%(port)s/Portal 
host = localhost 
port = 8080
ログイン後にコピー

RawConfigParser を使用します:

import ConfigParser 
 
cf = ConfigParser.RawConfigParser() 
 
print "use RawConfigParser() read" 
cf.read("test2.conf") 
print cf.get("portal", "url") 
 
print "use RawConfigParser() write" 
cf.set("portal", "url2", "%(host)s:%(port)s") 
print cf.get("portal", "url2")
ログイン後にコピー

端末出力を取得します:

use RawConfigParser() read 
http://%(host)s:%(port)s/Portal 
use RawConfigParser() write 
%(host)s:%(port)s
ログイン後にコピー

ConfigParser に変更します:

import ConfigParser 
 
cf = ConfigParser.ConfigParser() 
 
print "use ConfigParser() read" 
cf.read("test2.conf") 
print cf.get("portal", "url") 
 
print "use ConfigParser() write" 
cf.set("portal", "url2", "%(host)s:%(port)s") 
print cf.get("portal", "url2")
ログイン後にコピー

端末出力を取得します:

use ConfigParser() read 
http://localhost:8080/Portal 
use ConfigParser() write 
localhost:8080
ログイン後にコピー

SafeConfigParser に変更します:

import ConfigParser 
 
cf = ConfigParser.SafeConfigParser() 
 
print "use SafeConfigParser() read" 
cf.read("test2.conf") 
print cf.get("portal", "url") 
 
print "use SateConfigParser() write" 
cf.set("portal", "url2", "%(host)s:%(port)s") 
print cf.get("portal", "url2")
ログイン後にコピー

端末出力を取得 (効果は ConfigParser と同じです):

use SafeConfigParser() read 
http://localhost:8080/Portal 
use SateConfigParser() write 
localhost:8080
ログイン後にコピー

以上がPythonのConfigParser設定ファイルの詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート