一、yaml介紹
YAML全稱為”YAML Ain’t Markup Language”, 是一種可讀性高、用於表達數據序列化的格式,常用於配置文件、數據交換格式等場景。YAML文件的擴展名為.yml或.yaml,支持多種語言的解析,包括Python。相較於XML和JSON格式的文件,YAML文件更簡潔、易讀、易寫。Python中的yaml模塊,可以輕鬆地將Python中的數據結構轉化為YAML格式。
二、python3yaml基本使用
Python中的yaml模塊提供了基本的dump、dumps、load、loads函數來實現YAML與Python對象的相互轉換。
1. Python對象轉YAML
import yaml
# Python對象
data = {
'name': 'Jack',
'age': 30,
'hobbies': ['reading', 'sports'],
'contacts': {
'email': 'jack@example.com',
'phone': 123456789
}
}
# 將Python對象轉換為YAML格式
yaml_data = yaml.dump(data)
print(yaml_data)
運行以上代碼,將會輸出以下結果:
age: 30 contacts: email: jack@example.com phone: 123456789 hobbies: - reading - sports name: Jack
可以發現,Python數據結構被轉化成了YAML格式,對於Python中複雜的嵌套數據結構也同樣可被轉換為相應的YAML格式。
2. YAML轉Python對象
import yaml # YAML格式的數據 yaml_data = ''' name: Jack age: 30 hobbies: - reading - sports contacts: email: jack@example.com phone: 123456789 ''' # 將YAML格式數據轉換為Python對象 data = yaml.load(yaml_data, Loader=yaml.FullLoader) print(data)
運行以上代碼,將會輸出以下結果:
{'name': 'Jack', 'age': 30, 'hobbies': ['reading', 'sports'], 'contacts': {'email': 'jack@example.com', 'phone': 123456789}}
通過load函數,將YAML格式的數據轉換為Python對象,轉化後結果為Python中的一個字典對象。
三、yaml屬性設置
除了基本的dump、dumps、load、loads函數,yaml模塊還提供了許多屬性設置,來控制YAML的轉換過程。
1. 指定樣式
可以通過默認設置和配置樣式來指定轉化後的YAML樣式。比如對於默認情況下Python列表類型被轉換為YAML列表(使用“-”符號),也可以指定其轉換成塊或流樣式,即用中括號或無中括號的方式。
import yaml
# Python對象
data = {
'name': 'Jack',
'age': 30,
'hobbies': ['reading', 'sports', 'travel'],
'contacts': {
'email': 'jack@example.com',
'phone': 123456789
}
}
# flow樣式
yaml_data1 = yaml.dump(data, default_flow_style=True)
print(yaml_data1)
# block樣式
yaml_data2 = yaml.dump(data, default_flow_style=False)
print(yaml_data2)
運行以上代碼,將會輸出以下結果:
{age: 30, contacts: {email: jack@example.com, phone: 123456789}, hobbies: [reading, sports, travel], name: Jack}
age: 30
contacts:
email: jack@example.com
phone: 123456789
hobbies:
- reading
- sports
- travel
name: Jack
如果指定了flow樣式,則每個元素在同一行上展示;如果指定了block樣式,則每個元素單獨佔一行。
2. 控制縮進
如果希望輸出具有更好可讀性的YAML,可以通過設置縮進屬性進行設置。
import yaml
# Python對象
data = {
'name': 'Jack',
'age': 30,
'hobbies': ['reading', 'sports'],
'contacts': {
'email': 'jack@example.com',
'phone': 123456789
}
}
# 縮進為4
yaml_data1 = yaml.dump(data, default_flow_style=False, indent=4)
print(yaml_data1)
# 縮進為2
yaml_data2 = yaml.dump(data, default_flow_style=False, indent=2)
print(yaml_data2)
運行以上代碼,將會輸出以下結果:
age: 30
contacts:
email: jack@example.com
phone: 123456789
hobbies:
- reading
- sports
name: Jack
age: 30
contacts:
email: jack@example.com
phone: 123456789
hobbies:
- reading
- sports
name: Jack
可以發現,通過設置indent屬性可以控制YAML文件的縮進。值得注意的是,縮進屬性的值是一個整數,而不是將YAML文件中的空格數量作為值。
3. 設置標籤
可以為Python對象指定標籤,這些標籤可以作為對象構造函數的參數傳遞。
import yaml
# 自定義數據類型
class MyData:
def __init__(self, val):
self.value = val
def __repr__(self):
return 'MyData(%d)' % self.value
# Python對象
data = {
'name': 'Jack',
'age': 30,
'value': MyData(100)
}
# 定義標籤
yaml.add_representer(MyData, lambda dumper, data: dumper.represent_scalar('!MyData', str(data.value)))
# 將Python對象轉換為YAML格式
yaml_data = yaml.dump(data)
print(yaml_data)
# 將YAML格式數據轉換為Python對象
loaded_data = yaml.load(yaml_data, Loader=yaml.FullLoader)
print(loaded_data)
運行以上代碼,將會輸出以下結果:
age: 30
name: Jack
value: !MyData 100
{'name': 'Jack', 'age': 30, 'value': MyData(100)}
在以上示例中,我們使用add_representer函數定義了一個自定義類型的標籤,並將其作為輸出的結果。
四、yaml高級應用
以上我們已經介紹了基本的python3yaml使用方法和一些常見的屬性設置。接下來,我們來了解一些yaml更高級的應用場景,包括yaml文件的拆分、引用類型、注釋等。
1. yaml文件的拆分
在大型項目中,yaml文件通常會非常龐大,如果整個文件都寫在一個文件中,可讀性會變差。解決這個問題的一種方法是將文件拆分成多個小的yaml文件。
在將yaml文件拆分成多個小文件時,可能會存在重複的定義或屬性。為了解決這個問題,可以使用anchor(錨點)和alias(別名)屬性。
使用錨點,可以將同一個屬性定義為多個錨點並進行重用。使用別名,可以將重複使用的錨點取一個別名,並在其他地方引用它。yaml模塊實現了錨點和別名相關的函數,可以通過這些函數來實現yaml文件的拆分和重用。
2. 引用類型
引用類型是指“&name”和“*name”形式的語法,用於實現yaml文件中的跨位置引用。當一個錨點被定義時,可以通過在其他位置使用“*name”來引用它。
import yaml
# Python對象
data = {
'name': 'Jack',
'age': 30,
'emails': ['jack@example.com', 'jack@company.com'],
'contacts': {
'email': 'jack@example.com',
'phone': 123456789
}
}
# 定義錨點
yaml_str = '''
name: &name Jack
age: 30
emails: &emails
- jack@example.com
- jack@company.com
contacts:
email: *emails
phone: 123456789
'''
# 將YAML格式數據轉換為Python對象
loaded_data = yaml.load(yaml_str, Loader=yaml.FullLoader)
print(loaded_data)
以上程序段演示的是在yaml文件中引用錨點和別名的過程及轉換結果。
3. 注釋
注釋是指在yaml文件中對數據或配置項的解釋或說明,以幫助其他人更好地了解文件的內容。在yaml文件中,注釋以#字符開始。
import yaml
# 自定義數據類型
class MyData:
def __init__(self, val):
self.value = val
def __repr__(self):
return 'MyData(%d)' % self.value
# Python對象
data = {
# 用戶名
'name': 'Jack',
# 年齡
'age': 30,
# 愛好
'hobbies': ['reading', 'sports', 'travel'],
# 聯繫方式
'contacts': {
# 郵箱
'email': 'jack@example.com',
# 電話
'phone': 123456789
},
# 自定義類型
'value': MyData(100)
}
# 定義標籤
yaml.add_representer(MyData, lambda dumper, data: dumper.represent_scalar('!MyData', str(data.value)))
# 將Python對象轉換為YAML格式
yaml_data = yaml.dump(data)
print(yaml_data)
以上程序段演示了如何在yaml文件中使用注釋對數據或配置項的解釋或說明。
五、總結
本文詳細介紹了Python3yaml的基本使用方法及一些高級應用場景,包括yaml文件的拆分、引用類型、注釋等。通過學習本文內容,讀者可以更好地了解yaml格式的概念、使用方法和一些注意事項,從而更好地應用yaml在實際項目中。
原創文章,作者:GLYWR,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/368907.html
微信掃一掃
支付寶掃一掃