本文整理匯總了Python中ruamel.yaml.comments.CommentedSeq方法的典型用法代碼示例。如果您正苦於以下問題:Python comments.CommentedSeq方法的具體用法?Python comments.CommentedSeq怎麽用?Python comments.CommentedSeq使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類ruamel.yaml.comments
的用法示例。
在下文中一共展示了comments.CommentedSeq方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: reorder
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def reorder(data, strict=True):
if type(data) is CommentedMap:
order = ComposeFormat.order_map(list(data.keys()))
keys = list(data.keys())
while ComposeFormat.sorted_by_order(keys, order, strict) != keys:
for a, b in zip(ComposeFormat.sorted_by_order(keys, order, strict), keys):
if a == b:
continue
data.move_to_end(b)
break
keys = list(data.keys())
for key, item in data.items():
if key in ComposeFormat.NON_SORTABLE_ARRAYS:
continue
ComposeFormat.reorder(item, strict)
return data
if type(data) is CommentedSeq:
for i, value in enumerate(data):
if type(value) is not CommentedMap:
data[i] = ComposeFormat.fix_sexadecimal_numbers(value)
data.sort()
return data
return data
示例2: is_list
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def is_list(obj):
"""
Check if object is a list or the ruamel.yaml equivalent of a list
"""
return isinstance(obj, (list, CommentedSeq))
示例3: set_related_images
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def set_related_images(self):
"""
Find pullspecs in predefined locations and put all of them in the
.spec.relatedImages section (if it already exists, clear it first)
"""
named_pullspecs = self._named_pullspecs()
by_name = OrderedDict()
conflicts = []
for new in named_pullspecs:
# Keep track only of the first instance with a given name.
# Ideally, existing relatedImages should come first in the list,
# otherwise error messages could be confusing.
old = by_name.setdefault(new.name, new)
# Check for potential conflict (same name, different image)
if new.image != old.image:
msg = ("{old.description}: {old.image} X {new.description}: {new.image}"
.format(old=old, new=new))
conflicts.append(msg)
if conflicts:
raise RuntimeError("{} - Found conflicts when setting relatedImages:\n{}"
.format(self.path, "\n".join(conflicts)))
related_images = (self.data.setdefault("spec", CommentedMap())
.setdefault("relatedImages", CommentedSeq()))
del related_images[:]
for p in by_name.values():
log.debug("%s - Set relatedImage %s (from %s): %s",
self.path, p.name, p.description, p.image)
related_images.append(p.as_yaml_object())
示例4: delete_all_annotations
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def delete_all_annotations(obj):
if isinstance(obj, (dict, CommentedMap)):
obj.get("metadata", {}).pop("annotations", None)
for v in obj.values():
delete_all_annotations(v)
elif isinstance(obj, (list, CommentedSeq)):
for item in obj:
delete_all_annotations(item)
示例5: test_anchor_on_sequence
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def test_anchor_on_sequence(self):
# as reported by Bjorn Stabell
# https://bitbucket.org/ruamel/yaml/issue/7/anchor-names-not-preserved
from ruamel.yaml.comments import CommentedSeq
data = load("""
nut1: &alice
- 1
- 2
nut2: &blake
- some data
- *alice
nut3:
- *blake
- *alice
""")
l = data['nut1']
assert isinstance(l, CommentedSeq)
assert l.yaml_anchor() is not None
assert l.yaml_anchor().value == 'alice'
示例6: test_before_top_seq_from_scratch
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def test_before_top_seq_from_scratch(self):
from ruamel.yaml.comments import CommentedSeq
data = CommentedSeq()
data.append('a')
data.append('b')
data.yaml_set_start_comment('Hello\nWorld\n')
print(round_trip_dump(data))
compare(data, """
{comment} Hello
{comment} World
- a
- b
""".format(comment='#'))
# nested variants
示例7: test_before_nested_seq_from_scratch
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def test_before_nested_seq_from_scratch(self):
from ruamel.yaml.comments import CommentedMap, CommentedSeq
data = CommentedMap()
datab = CommentedSeq()
data['a'] = 1
data['b'] = datab
datab.append('c')
datab.append('d')
data['b'].yaml_set_start_comment('Hello\nWorld\n', indent=2)
compare(data, """
a: 1
b:
{comment} Hello
{comment} World
- c
- d
""".format(comment='#'))
示例8: to_yaml
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def to_yaml(self, data):
self._should_be_list(data)
return CommentedSeq([self._validator.to_yaml(item) for item in data])
示例9: data
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def data(self):
"""
Returns raw data representation of the document or document segment.
Mappings are rendered as ordered dicts, sequences as lists and scalar values
as whatever the validator returns (int, string, etc.).
If no validators are used, scalar values are always returned as strings.
"""
if isinstance(self._value, CommentedMap):
mapping = OrderedDict()
for key, value in self._value.items():
"""
#if isinstance(key, YAML):
#mapping[key.data] = value.data if isinstance(value, YAML) else value
"""
mapping[key.data] = value.data
return mapping
elif isinstance(self._value, CommentedSeq):
return [item.data for item in self._value]
else:
return self._value
示例10: as_marked_up
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def as_marked_up(self):
"""
Returns ruamel.yaml CommentedSeq/CommentedMap objects
with comments. This can be fed directly into a ruamel.yaml
dumper.
"""
return self._chunk.contents
示例11: text
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def text(self):
"""
Return string value of scalar, whatever value it was parsed as.
"""
if isinstance(self._value, CommentedMap):
raise TypeError("{0} is a mapping, has no text value.".format(repr(self)))
if isinstance(self._value, CommentedSeq):
raise TypeError("{0} is a sequence, has no text value.".format(repr(self)))
return self._text
示例12: __gt__
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def __gt__(self, val):
if isinstance(self._value, CommentedMap) or isinstance(
self._value, CommentedSeq
):
raise TypeError("{0} not an orderable type.".format(repr(self._value)))
return self._value > val
示例13: __lt__
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def __lt__(self, val):
if isinstance(self._value, CommentedMap) or isinstance(
self._value, CommentedSeq
):
raise TypeError("{0} not an orderable type.".format(repr(self._value)))
return self._value < val
示例14: is_sequence
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def is_sequence(self):
return isinstance(self._value, CommentedSeq)
示例15: scalar
# 需要導入模塊: from ruamel.yaml import comments [as 別名]
# 或者: from ruamel.yaml.comments import CommentedSeq [as 別名]
def scalar(self):
if isinstance(self._value, (CommentedMap, CommentedSeq)):
raise TypeError("{0} has no scalar value.".format(repr(self)))
return self._value