欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用 Python 解析配置文件格式

 更新時(shí)間:2021年07月05日 14:33:00   投稿:mrr  
選擇配置格式是一種微妙的權(quán)衡。但是,一旦你做出決定,Python 就可以使用少量代碼來(lái)解析大多數(shù)流行的格式。今天通過(guò)本文給大家分享 Python 解析配置文件格式的問(wèn)題,感興趣的朋友一起看看吧

第一步是選擇配置文件的格式:INI、JSON、YAML 或 TOML。

有時(shí),程序需要足夠的參數(shù),將它們?nèi)孔鳛槊钚袇?shù)或環(huán)境變量既不讓人愉快也不可行。 在這些情況下,你將需要使用配置文件。

有幾種流行的配置文件格式。其中包括古老的(雖然有時(shí)定義不明確)INI 格式,雖然流行但有時(shí)難以手寫的 JSON 格式,使用廣泛但有時(shí)在細(xì)節(jié)方面令人意外的 YAML 格式,以及很多人還沒(méi)有聽(tīng)說(shuō)過(guò)的最新出現(xiàn)的 TOML。

你的首要任務(wù)是選擇一種格式,然后記錄該選擇。解決了這個(gè)簡(jiǎn)單的部分之后就是時(shí)候解析配置了。

有時(shí),在配置中擁有一個(gè)與“抽象“數(shù)據(jù)相對(duì)應(yīng)的類是一個(gè)不錯(cuò)的想法。因?yàn)檫@段代碼不會(huì)對(duì)配置做任何事情,所以這是展示解析邏輯最簡(jiǎn)單的方式。

想象一下文件處理器的配置:它包括一個(gè)輸入目錄、一個(gè)輸出目錄和要提取的文件。

配置類的抽象定義可能類似于:

from__future__import annotations
import attr
 
@attr.frozen
class Configuration:
 @attr.frozen
 class Files:
input_dir:str
output_dir:str
files: Files
 @attr.frozen
 class Parameters:
patterns: List[str]
parameters: Parameters

為了使特定于格式的代碼更簡(jiǎn)單,你還需要編寫一個(gè)函數(shù)來(lái)從字典中解析此類。請(qǐng)注意,這假設(shè)配置將使用破折號(hào),而不是下劃線。 這種差異并不少見(jiàn)。

def configuration_from_dict(details):
    files = Configuration.Files(
        input_dir=details["files"]["input-dir"],
        output_dir=details["files"]["output-dir"],
    )
    parameters = Configuration.Paraneters(
        patterns=details["parameters"]["patterns"]
    )
    return Configuration(
        files=files,
        parameters=parameters,
    )

JSON

JSON(JavaScript Object Notation)是一種類似于 JavaScript 的格式。

以下是 JSON 格式的示例配置:

json_config = """
{
    "files": {
        "input-dir": "inputs",
        "output-dir": "outputs"
    },
    "parameters": {
        "patterns": [
            "*.txt",
            "*.md"
        ]
    }
}
"""

解析邏輯使用 json 模塊將 JSON 解析為 Python 的內(nèi)置數(shù)據(jù)結(jié)構(gòu)(字典、列表、字符串),然后從字典中創(chuàng)建類:

import json
def configuration_from_json(data):
    parsed = json.loads(data)
    return configuration_from_dict(parsed)

INI

INI 格式,最初只在 Windows 上流行,之后成為配置標(biāo)準(zhǔn)格式。

這是與 INI 相同的配置:

ini_config="""
[files]
input-dir = inputs
output-dir = outputs
 
[parameters]
patterns = ['*.txt', '*.md']
"""

Python 可以使用內(nèi)置的 configparser 模塊解析它。解析器充當(dāng)類似  dict 的對(duì)象,因此可以直接傳遞給  configuration_from_dict :

import configparser
 
def configuration_from_ini(data):
parser=configparser.ConfigParser()
parser.read_string(data)
 return configuration_from_dict(parser)

YAML

YAML(Yet Another Markup Language)是 JSON 的擴(kuò)展,旨在更易于手動(dòng)編寫。為了實(shí)現(xiàn)了這一點(diǎn),部分原因是有一個(gè)很長(zhǎng)的規(guī)范。

以下是 YAML 中的相同配置:

yaml_config = """
files:
  input-dir: inputs
  output-dir: outputs
parameters:
  patterns:
  - '*.txt'
  - '*.md'
"""

要讓 Python 解析它,你需要安裝第三方模塊。最受歡迎的是 PyYAML ( pip install pyyaml )。 YAML 解析器還返回可以傳遞給  configuration_from_dict 的內(nèi)置 Python 數(shù)據(jù)類型。但是,YAML 解析器需要一個(gè)字節(jié)流,因此你需要將字符串轉(zhuǎn)換為字節(jié)流。

import io
import yaml
def configuration_from_yaml(data):
    fp = io.StringIO(data)
    parsed = yaml.safe_load(fp)
    return configuration_from_dict(parsed)

TOML

TOML(Tom's Own Markup Language)旨在成為 YAML 的輕量級(jí)替代品。其規(guī)范比較短,已經(jīng)在一些地方流行了(比如 Rust 的包管理器 Cargo 就用它來(lái)進(jìn)行包配置)。

這是與 TOML 相同的配置:

toml_config= """
[files]
input-dir = "inputs"
output-dir = "outputs"
 
[parameters]
patterns = [ "*.txt", "*.md",]
"""

為了解析 TOML,你需要安裝第三方包。最流行的一種被簡(jiǎn)單地稱為 toml 。 與 YAML 和 JSON 一樣,它返回基本的 Python 數(shù)據(jù)類型。

import toml
def configuration_from_toml(data):
    parsed = toml.loads(data)
    return configuration_from_dict(parsed)

總結(jié)

選擇配置格式是一種微妙的權(quán)衡。但是,一旦你做出決定,Python 就可以使用少量代碼來(lái)解析大多數(shù)流行的格式。

到此這篇關(guān)于使用 Python 解析配置文件格式的文章就介紹到這了,更多相關(guān)Python 解析配置文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python hexstring-list-str之間的轉(zhuǎn)換方法

    Python hexstring-list-str之間的轉(zhuǎn)換方法

    今天小編就為大家分享一篇Python hexstring-list-str之間的轉(zhuǎn)換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-06-06
  • 深度定制Python的Flask框架開(kāi)發(fā)環(huán)境的一些技巧總結(jié)

    深度定制Python的Flask框架開(kāi)發(fā)環(huán)境的一些技巧總結(jié)

    現(xiàn)在越來(lái)越多的人使用virtualenv虛擬環(huán)境部署Python項(xiàng)目,包括針對(duì)框架的實(shí)例文件夾與版本控制布置,這里我們就來(lái)整理關(guān)于深度定制Python的Flask框架開(kāi)發(fā)環(huán)境的一些技巧總結(jié)
    2016-07-07
  • 如何在Python項(xiàng)目中做多環(huán)境配置(環(huán)境變量使用.env文件)

    如何在Python項(xiàng)目中做多環(huán)境配置(環(huán)境變量使用.env文件)

    實(shí)際工程開(kāi)發(fā)中常常會(huì)對(duì)開(kāi)發(fā)、測(cè)試和生產(chǎn)等不同環(huán)境配置不同的數(shù)據(jù)庫(kù)環(huán)境,傳統(tǒng)方式可以通過(guò)添加不同環(huán)境的配置文件達(dá)到部署時(shí)的動(dòng)態(tài)切換的效果,這篇文章主要給大家介紹了關(guān)于如何在Python項(xiàng)目中做多環(huán)境配置的相關(guān)資料,環(huán)境變量使用.env文件,需要的朋友可以參考下
    2024-06-06
  • 在django中圖片上傳的格式校驗(yàn)及大小方法

    在django中圖片上傳的格式校驗(yàn)及大小方法

    今天小編就為大家分享一篇在django中圖片上傳的格式校驗(yàn)及大小方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-07-07
  • python pytorch模型轉(zhuǎn)onnx模型的全過(guò)程(多輸入+動(dòng)態(tài)維度)

    python pytorch模型轉(zhuǎn)onnx模型的全過(guò)程(多輸入+動(dòng)態(tài)維度)

    這篇文章主要介紹了python pytorch模型轉(zhuǎn)onnx模型的全過(guò)程(多輸入+動(dòng)態(tài)維度),本文給大家記錄記錄了pt文件轉(zhuǎn)onnx全過(guò)程,簡(jiǎn)單的修改即可應(yīng)用,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2024-03-03
  • Python命令行參數(shù)argv和argparse該如何使用

    Python命令行參數(shù)argv和argparse該如何使用

    這篇文章主要介紹了Python命令行參數(shù)argv和argparse該如何使用,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下
    2021-02-02
  • Python利用prettytable庫(kù)輸出好看的表格

    Python利用prettytable庫(kù)輸出好看的表格

    prettytable庫(kù)就是這么一個(gè)工具,prettytable可以打印出美觀的表格,并且對(duì)中文支持相當(dāng)好。本文將介紹如何通過(guò)prettytable輸出好看的表格,需要的可以參考一下
    2022-01-01
  • 使用Python第三方庫(kù)xlrd讀取Excel中的數(shù)據(jù)的流程步驟

    使用Python第三方庫(kù)xlrd讀取Excel中的數(shù)據(jù)的流程步驟

    這篇文章主要給大家介紹了使用Python第三方庫(kù)xlrd讀取Excel中的數(shù)據(jù)的流程步驟,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-12-12
  • python 輪詢執(zhí)行某函數(shù)的2種方式

    python 輪詢執(zhí)行某函數(shù)的2種方式

    這篇文章主要介紹了python 輪詢執(zhí)行某函數(shù)的2種方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05
  • python正則表達(dá)式及使用正則表達(dá)式的例子

    python正則表達(dá)式及使用正則表達(dá)式的例子

    正則表達(dá)是用來(lái)匹配字符串,這篇文章給大家介紹了python正則表達(dá)式及正則表達(dá)式的例子,文章給大家提到了正則表達(dá)式語(yǔ)法規(guī)則,感興趣的朋友一起看看吧
    2018-01-01

最新評(píng)論