python Yaml、Json、Dict之間的轉(zhuǎn)化
Json To Dict
import json jsonData = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; print(jsonData) print(type(jsonData)) text = json.loads(jsonData) print(text) print(type(text)) ####################### {"a":1,"b":2,"c":3,"d":4,"e":5} <class 'str'> {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5} <class 'dict'>
Dict To Json
import json textDict = {"a":1,"b":2,"c":3,"d":4,"e":5} print(textDict) print(type(textDict)) # 字典轉(zhuǎn)化為json textJson = json.dumps(textDict) print(textJson) print(type(textJson)) ######################## {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5} <class 'dict'> {"a": 1, "b": 2, "c": 3, "d": 4, "e": 5} <class 'str'>
Dict To Yaml
import yaml dictText = { "apiVersion": "rbac.authorization.k8s.io/v1", "kind": "ClusterRoleBinding", "metadata": { "name": "admin-user" }, "roleRef": { "apiGroup": "rbac.authorization.k8s.io", "kind": "ClusterRole", "name": "cluster-admin" }, "subjects": [ { "kind": "ServiceAccount", "name": "admin-user", "namespace": "kube-system" } ] } print(type(dictText)) yamlText = yaml.dump(dictText) print(yamlText) print(type(yamlText)) #############################3 <class 'dict'> apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: admin-user roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: cluster-admin subjects: - kind: ServiceAccount name: admin-user namespace: kube-system <class 'str'>
Json To Yaml
Json -> Dict -> Yaml
import json,yaml jsonData = '{"listDict":{"a":1,"b":2,"c":3,"d":4,"e":5}}'; print(jsonData) print(type(jsonData)) # Json -> Dict text = json.loads(jsonData) print(text) print(type(text)) # Dict -> Yaml textYaml = yaml.dump(text) print(textYaml) print(type(textYaml)) ############################# {"listDict":{"a":1,"b":2,"c":3,"d":4,"e":5}} <class 'str'> {'listDict': {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}} <class 'dict'> listDict: a: 1 b: 2 c: 3 d: 4 e: 5 <class 'str'>
Yaml -> Dict
import yaml yamlText =''' apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: admin-user roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: cluster-admin subjects: - kind: ServiceAccount name: admin-user namespace: kube-system''' print(yamlText) print(type(yamlText)) # Yaml -> Dict dictText = yaml.load(yamlText,Loader=yaml.FullLoader) print(dictText) print(type(dictText)) ############################# apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: admin-user roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: cluster-admin subjects: - kind: ServiceAccount name: admin-user namespace: kube-system <class 'str'> {'apiVersion': 'rbac.authorization.k8s.io/v1', 'kind': 'ClusterRoleBinding', 'metadata': {'name': 'admin-user'}, 'roleRef': {'apiGroup': 'rbac.authorization.k8s.io', 'kind': 'ClusterRole', 'name': 'cluster-admin'}, 'subjects': [{'kind': 'ServiceAccount', 'name': 'admin-user', 'namespace': 'kube-system'}]} <class 'dict'>
關(guān)于 yaml -> dict 需要注意
yaml 5.1版本后棄用了yaml.load(file)這個用法,因為覺得很不安全,5.1版本之后就修改了需要指定Loader,通過默認加載器(FullLoader)禁止執(zhí)行任意函數(shù)
import yaml yamlText =''' apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: admin-user roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: cluster-admin subjects: - kind: ServiceAccount name: admin-user namespace: kube-system''' print(yamlText) print(type(yamlText)) # yaml -> dict 沒有設(shè)置 ,Loader=yaml.FullLoader 執(zhí)行后如下含有警告 dictText = yaml.load(yamlText) print(dictText) print(type(dictText)) ######################### apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: admin-user roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: cluster-admin subjects: - kind: ServiceAccount name: admin-user namespace: kube-system <class 'str'> /Users/yyj/Desktop/Project/HelloBike/TimeCalc/pydict2json/dict2json.py:88: YAMLLoadWarning: calling yaml.load() without Loader=... is deprecated, as the default Loader is unsafe. Please read https://msg.pyyaml.org/load for full details. dictText = yaml.load(yamlText) {'apiVersion': 'rbac.authorization.k8s.io/v1', 'kind': 'ClusterRoleBinding', 'metadata': {'name': 'admin-user'}, 'roleRef': {'apiGroup': 'rbac.authorization.k8s.io', 'kind': 'ClusterRole', 'name': 'cluster-admin'}, 'subjects': [{'kind': 'ServiceAccount', 'name': 'admin-user', 'namespace': 'kube-system'}]} <class 'dict'>
1、警告提示
YAMLLoadWarning: calling yaml.load() without Loader=... is deprecated, as the default
Loader is unsafe. Please read https://msg.pyyaml.org/load for full details.
2.主要原因
yaml 5.1版本后棄用了yaml.load(file)這個用法,因為覺得很不安全,5.1版本之后就修改了需要指定Loader,通過默認加載器(FullLoader)禁止執(zhí)行任意函數(shù)
3.解決方法
1.yaml.load(f, Loader=yaml.FullLoader)
2.yaml.warnings({'YAMLLoadWarning': False}) # 全局設(shè)置警告,不推薦
Loader的幾種加載方式
- BaseLoader--僅加載最基本的YAML
- SafeLoader--安全地加載YAML語言的子集。建議用于加載不受信任的輸入。
- FullLoader--加載完整的YAML語言。避免任意代碼執(zhí)行。這是當前(PyYAML 5.1)默認加載器調(diào)用yaml.load(input)(發(fā)出警告后)。
- UnsafeLoader--(也稱為Loader向后兼容性)原始的Loader代碼,可以通過不受信任的數(shù)據(jù)輸入輕松利用。
至此,Yaml 、Json 、Dict 之間的轉(zhuǎn)化 介紹完了
以上就是python Yaml 、Json 、Dict 之間的轉(zhuǎn)化的詳細內(nèi)容,更多關(guān)于python Yaml 、Json 、Dict的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Django app配置多個數(shù)據(jù)庫代碼實例
這篇文章主要介紹了Django app配置多個數(shù)據(jù)庫代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-12-12Python輸入正負10進制,轉(zhuǎn)4位16進制問題
這篇文章主要介紹了Python輸入正負10進制,轉(zhuǎn)4位16進制問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06Python數(shù)據(jù)結(jié)構(gòu)之優(yōu)先級隊列queue用法詳解
queue庫提供了一個適用于多線程編程的先進先出(FIFO)數(shù)據(jù)結(jié)構(gòu),可以用來在生產(chǎn)者與消費者線程之間安全地傳遞消息或其他數(shù)據(jù),它會為調(diào)用者處理鎖定,使多個線程可以安全而更容易地處理同一個Queue實例.Queue的大小可能受限,以限制內(nèi)存使用或處理,需要的朋友可以參考下2021-05-05