如何在python yaml文件

时间:2015-05-08 23:05:59

标签: python yaml pyyaml

我正在写这样的yaml文件

with open(fname, "w") as f:
     yaml.safe_dump({'allow':'', 'deny': ''}, f,
                    default_flow_style=False, width=50, indent=4)

输出:

allow: ''

我想输出为

allow:

我该怎么做?

4 个答案:

答案 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