使用python檢查yaml配置文件是否符合要求
更新時間:2020年04月09日 08:42:15 作者:wangjiadongge
這篇文章主要介紹了使用python檢查yaml配置文件是否符合要求,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
我就廢話不多說了,大家還是直接看代碼吧!
# coding=utf-8
import logging
import yaml
import os
import sys
reload(sys)
sys.setdefaultencoding("utf-8")
# 獲取當前目錄的路徑
cur_dir = os.path.abspath('.')
def check_dt_pacsscp(config):
"""
用來檢查文件配置是否正確
"""
#將配置config.yaml配置文件以字典方式讀取
dts_method = config['service']['method']
dts_dup_check = config['service']['pacsscp_dup_check_off']
dts_interval = config['scheduler']['interval']
#判斷對接方式是否是pacsscp
if dts_method == 'pacsscp':
if dts_dup_check == True and dts_interval == 3:
return True
else:
return False
else:
#打印error級別的錯誤
print "\033[31m Error:method not is pacsscp!!!\033[0m"
return False
if __name__ == "__main__":
# 加載yaml配置
config_yaml = os.path.join(cur_dir, 'config.yaml')
with open(config_yaml, 'rt') as f:
config = yaml.safe_load(f.read())
#dt相關路徑和配置
dt_path = config['path']['docking-toolbox']
dt_config_path = os.path.join(dt_path, 'config.yaml')
with open(dt_config_path, 'rt') as f:
dt_config = yaml.safe_load(f.read())
if check_dt_pacsscp(dt_config):
print (u"\033[32m 校驗通過~\033[0m")
else:
print (u'\033[32m 校驗未通過, 請檢查配置!\033[0m ')
以下是用正則獲取不是yaml配置文件的
# coding=utf-8
"""
作業(yè)要求, 完善check_txpacs_version函數
"""
import logging
import traceback
import yaml
import os
import sys
import re
reload(sys)
sys.setdefaultencoding("utf-8")
# 獲取當前目錄的路徑
cur_dir = os.path.abspath('.')
def check_txpacs_version(config, constant):
"""
高難度
校驗txpacs版本, 若版本<1.4, 則回調中不能出現received_start_timestamp和received_end_timestamp這兩個參數,
若不合法打印error級別的提示;
校驗txpacs的自動清理功能是否合法: 若dt版本<1.3.8, 則不做要求,
若dt版本>=1.3.8, 則要求txpacs版本必須為1.5.1及以上版本, 且txpacs配置的clean_date需配置為正整數
(docking-toolbox的版本號可以從文件'docking-toolbox/toolbox/utils/constant.py'中讀取),
若不合法打印error級別的提示.
根據以上結果, 返回返回值.
:param config: txpacs的配置
:param constant: docking-toolbox/toolbox/utils/constant.py文件內容
:return: True: 通過
False: 不通過
"""
# 獲取txpacs的版本號
jar_file = os.listdir(txpacs_path)
jar_file.sort(reverse=True)
jar_ver = jar_file[0]
jar_version = re.search('txpacs-(.*?).jar', jar_ver)
#txpacs的版本號
txpacs_version = jar_version.group(1)
#docking-tools的版本號
dt_version = re.search('DT_VERSIONS.*?"(.*?)"',constant).group(1)
#打開txpacs的配置文件
with open(txpacs_config_path, 'rt') as f:
txpacs_file = f.read()
#判斷txpacs的版本號是否小于1.4
if txpacs_version < '1.4':
#判斷received_start_timestamp" and "received_end_timestamp"兩個參數是否出現在txpacs配置文件中
if "received_start_timestamp" and "received_end_timestamp" not in txpacs_file:
return True
else:
print "\033[31m Error:當前的txpacs版本號是txpacs-%s ,不應該存在received_start_timestamp和received_end_timestamp\033[0m"%txpacs_version
return False
#如果txpacs版本號大于等于1.4
else:
#判斷DT版本是否大于1.3.8
if dt_version >= '1.3.8':
if txpacs_version >= '1.5.1':
if config['store']['clean_date'] > 0:
return True
else:
print "\033[31m Error:txpacs配置文件中clean_date應為正整數 \033[0m"
return False
else:
print "\033[31m Error:當前DT版本大于1.3.8,txpacs版本必須大于等于1.5.1\033[0m"
return False
else:
return True
if __name__ == "__main__":
# 加載yaml配置
config_yaml = os.path.join(cur_dir, 'config.yaml')
with open(config_yaml, 'rt') as f:
config = yaml.safe_load(f.read())
# txpacs相關路徑和配置
txpacs_path = config['path']['txpacs']
txpacs_config_path = os.path.join(txpacs_path, 'conf.yml')
with open(txpacs_config_path, 'rt') as f:
txpacs_config = yaml.safe_load(f.read())
# dt相關路徑和配置
dt_path = config['path']['docking-toolbox']
dt_constant_path = os.path.join(dt_path, 'toolbox', 'utils', 'constant.py')
with open(dt_constant_path, 'rt') as f:
dt_constant = f.read()
if check_txpacs_version(txpacs_config, dt_constant):
print (u"\033[32m 校驗通過~\033[0m")
else:
print (u'\033[32m 校驗未通過, 請檢查配置! \033[0m')
以上這篇使用python檢查yaml配置文件是否符合要求就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python+Django實現簡單HelloWord網頁的示例代碼
本文主要介紹了Python+Django實現簡單HelloWord網頁的示例代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04

