PyYAMl文件读取「建议收藏」

PyYAMl文件读取「建议收藏」yaml文件读取(5.1版本前后)yaml.load(input)弃用了,随后发现,5.1之后的需要加一个加载器才可以正常运行,针对该变化,作了以下比较yaml5.1之前的使用方法:defoperateYaml(self,filename):file=open(filename,”r”,encoding=’utf-8′)data=yaml.load(file)file.close()returndata

大家好,欢迎来到IT知识分享网。

yaml 文件读取(5.1版本前后)

yaml.load(input)弃用了,随后发现,5.1之后的需要加一个加载器才可以正常运行,针对该变化,作了以下比较

yaml 5.1之前的使用方法:

 def operateYaml(self,filename):
         file = open(filename, "r",encoding='utf-8')
         data = yaml.load(file)
         file.close()
         return data

yaml 5.1之后的使用方式有两种:

 def operateYaml(self,filename):
         file = open(filename, "r",encoding='utf-8')
         data = yaml.load(file,Loader=yaml.FullLoader)
          #loader可选择BaseLoader、SafeLoader、FullLoader、UnsafeLoader
         file.close()     
         return data
 def operateYaml(self,filename):
         file = open(filename, "r",encoding='utf-8')
         data = yaml.full_load(file) #可使用3种不同的加载方式:yaml.safe_load、yaml.full_load、yaml.unsafe_load
         file.close()
         return data

针对不同的需要,加载器有如下几种类型:

BaseLoader:仅加载最基本的YAML
SafeLoader:安全地加载YAML语言的子集。建议用于加载不受信任的输入。(safe_load)
FullLoader:加载完整的YAML语言。避免任意代码执行。这是当前(PyYAML 5.1)默认加载器调用yaml.load(input)(发出警告后)(full_load)
UnsafeLoader(也称为Loader向后兼容性):原始的Loader代码,可以通过不受信任的数据输入轻松利用。(unsafe_load) 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/25530.html

(0)

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信