我正在写这样的yaml文件
with open(fname, "w") as f:
yaml.safe_dump({'allow':'', 'deny': ''}, f,
default_flow_style=False, width=50, indent=4)
输出:
allow: ''
我想输出为
allow:
我该怎么做?
答案 0 :(得分:5)
如果您加载YAML src
allow:
进入Python后,您将None
分配给密钥allow
,这是正确的行为。
如果您使用ruamel.yaml(其中我是作者),并且RoundTripDumper
None
,则会根据需要编写{IMO最具可读性,尽管不明确):
import ruamel.yaml
print ruamel.yaml.dump(dict(allow=None), Dumper=ruamel.yaml.RoundTripDumper)
会给你:
allow:
你也可以正确地往返这个:
import ruamel.yaml
yaml_src = """
allow:
key2: Hello # some test
"""
data = ruamel.yaml.load(yaml_src, ruamel.yaml.RoundTripLoader)
print('#### 1')
print(data['allow'])
print('#### 2')
print(ruamel.yaml.dump(data, Dumper=ruamel.yaml.RoundTripDumper))
print('#### 3')
print(type(data))
获取输出:
#### 1
None
#### 2
allow:
key2: Hello # some test
#### 3
<class 'ruamel.yaml.comments.CommentedMap'>
在上面,data
是ordereddict的子类,这是跟踪输入的流式,处理附加到行的注释,键的顺序等所必需的。
这样的子类可以动态创建,但通常更容易从一些可读且格式良好的YAML代码开始(可能已保存在光盘上),然后更新/扩展值。
答案 1 :(得分:3)
from yaml import SafeDumper
import yaml
data = {'deny': None, 'allow': None}
SafeDumper.add_representer(
type(None),
lambda dumper, value: dumper.represent_scalar(u'tag:yaml.org,2002:null', '')
)
with open('./yadayada.yaml', 'w') as output:
yaml.safe_dump(data, output, default_flow_style=False)
有一种方法可以将这个内置到python yaml本身。上面的代码将生成一个包含以下内容的文件:
allow:
deny:
答案 2 :(得分:2)
使用替换,这似乎很简单:
import yaml
fname = 'test.yaml'
with open(fname, "w") as f:
yaml_str = yaml.safe_dump({'allow':'', 'deny': ''},
default_flow_style=False,
width=50,
indent=4).replace(r"''", '')
f.write(yaml_str)
您是否有理由避免replace
?
缺点是重新加载yaml文件不会重现您的输入:
>>> print yaml.safe_load(open(fname))
{'deny': None, 'allow': None}
答案 3 :(得分:1)
要从python中读取None
类型,请在yaml中使用null
这样的YAML文件test.yml
foo: null
bar: null
将被python读取为
import yaml
test = yaml.load(open('./test.yml'))
print(test)
foo: None
bar: None