YAML文件畅达包更新程序
问题描述:
我有一个Python脚本,想读一组畅达食谱,并与一些信息进行更新(如文件:https://github.com/williamjamir/staged-recipes/blob/850760fb63c0fc000b95ac27680ec018fa94dcb7/recipes/pyexcel-ezodf/meta.yaml):YAML文件畅达包更新程序
我使用这个:
from ruamel.yaml import YAML
from yaml.constructor import ConstructorError
from yaml.scanner import ScannerError
yaml = YAML(typ='jinja2')
yaml.allow_duplicate_keys = True
with open(file_name) as fp:
yalm_file = yaml.load(fp)
当我打印使用原始文件yaml_file
:
with open(path_file, 'w') as fp:
yaml.dump(yaml_file, fp, allow_unicode=True, explicit_start=True)
输出包含与类型很多标签和注释 的数据如下:
--- !!python/object/apply:ruamel.yaml.comments.CommentedMap
dictitems:
about: !!python/object/apply:ruamel.yaml.comments.CommentedMap
dictitems: {home: 'https://github.com/soedinglab/xxmotif', license:
GPLv3, license_file: LICENSE,
summary: 'eXhaustive, weight matriX-based motif discovery in nucleotide sequences'}
state:
_yaml_format: !!python/object/new:ruamel.yaml.comments.Format
state: !!python/tuple
- null
- {_flow_style: false}
我该如何解决这个问题?
答
YAML
实例的dump()
方法不采用您提供的参数(allow_unicode=True, explicit_start=True
)。由于你没有提供完整的工作程序,我只能猜测你(也)做了import ruamel.yaml as yaml
(或甚至import yaml
)。
通过的Jinja2插件,其与标准的Jinja2模板语法涉及(通常与YAML解析器解析之前处理)完成的转换需要在加载和而倾倒工作要做。所以你需要使用相同的YAML(typ='jinja2')
实例来完成:
import sys
file_name = 'meta.yaml'
from ruamel.yaml import YAML
from yaml.constructor import ConstructorError
from yaml.scanner import ScannerError
yaml = YAML(typ='jinja2')
yaml.allow_duplicate_keys = True
yaml.indent(sequence=4, offset=2)
yaml.preserve_quotes = True
# yaml.explicit_start = True
with open(file_name) as fp:
data = yaml.load(fp)
yaml.dump(data, sys.stdout)
给出确切的往返您的输入:
{% set name = "pyexcel-ezodf" %}
{% set version = "0.3.3" %}
{% set sha256 = "26ddddc61c6bbe2641a15964ba57eaf92a171478e7ed9efb9ae4db1567d0998
c" %}
package:
name: {{ name|lower }}
version: {{ version }}
source:
fn: {{ name }}-{{ version }}.tar.gz
# The github url is been used because the tar.gz from pypi is missing the CONT
RIBUTORS.rst file
url: https://github.com/pyexcel/{{ name }}/archive/v{{ version }}.tar.gz
sha256: {{ sha256 }}
build:
noarch: python
number: 0
script: python setup.py install --single-version-externally-managed --record r
ecord.txt
requirements:
build:
- python
- setuptools
run:
- python
- lxml
test:
imports:
- ezodf
about:
home: https://github.com/pyexcel/pyexcel-ezodf
license: MIT
license_family: MIT
license_file: '{{ environ["RECIPE_DIR"] }}/LICENSE'
summary: 'A Python package to create/manipulate OpenDocumentFormat files'
description: |
'ezodf is a Python package to create new or open existing' +
'OpenDocument (ODF) files to extract, add, modify or delete document data' +
'forked from dead project https://bitbucket.org/mozman/ezodf' +
'format and to/from databases' +
''
dev_url: https://github.com/pyexcel/pyexcel-ezodf
extra:
recipe-maintainers:
- williamjamir
你并不需要设置allow_unicode
,那就是默认YAML.dump()
。
@AnthonIt可以是jupyter重写YAML功能。 – ypriverol
我不知道jupyter在做什么,但是如果你的代码仍然是'yaml.dump(data,sys.stdout,allow_unicode = True)',它应该会抛出一个'TypeError'。如果加载和转储没有在同一个上下文中完成,我不知道你的'yaml'是从哪里来的,但是无论如何,你可以从ruamel.yaml import YAML; yaml = YAML(typ ='jinja2')'就在你转储之前 – Anthon
我删除了我的脚本中的所有复杂性,只使用你的代码作为例子。我有这个错误:“File”/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/ruamel/yaml/jinja2/__plug_in__.py“,第58行,写在 data = data.replace(k,self.reverse [k]) TypeError:期望的字节,bytearray或缓冲区兼容对象 – ypriverol