當前位置: 首頁>>代碼示例>>Python>>正文


Python pyparsing.ParserElement方法代碼示例

本文整理匯總了Python中pyparsing.ParserElement方法的典型用法代碼示例。如果您正苦於以下問題:Python pyparsing.ParserElement方法的具體用法?Python pyparsing.ParserElement怎麽用?Python pyparsing.ParserElement使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pyparsing的用法示例。


在下文中一共展示了pyparsing.ParserElement方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _set_matcher_element_attributes

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def _set_matcher_element_attributes(self, element):
        # Set the ParserElement's action.
        element.setParseAction(self._parse_action)

        # Save the element's original postParse function.
        closure = element.postParse

        # Set a new function and use the original function for returning values.
        def postParse(instring, loc, tokenlist):
            if isinstance(tokenlist, pyparsing.ParseResults):
                s = " ".join(tokenlist.asList())
            elif isinstance(tokenlist, list):
                s = "".join(tokenlist)
            elif isinstance(tokenlist, string_types):
                s = tokenlist
            else:
                raise TypeError("postParse received invalid tokenlist %s"
                                % tokenlist)
            self.matching_slice = slice(loc - len(s), loc)
            return closure(instring, loc, tokenlist)

        element.postParse = postParse

        # Return the element.
        return element 
開發者ID:Danesprite,項目名稱:pyjsgf,代碼行數:27,代碼來源:expansions.py

示例2: get_protein_modification_language

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def get_protein_modification_language(concept_qualified: ParserElement) -> ParserElement:
    """Build a protein modification parser."""
    pmod_concept = MatchFirst([
        concept_qualified,
        pmod_default_ns,
        pmod_legacy_ns,
    ])

    return pmod_tag + nest(
        Group(pmod_concept)(CONCEPT)
        + Optional(
            WCW
            + amino_acid(PMOD_CODE)
            + Optional(WCW + ppc.integer(PMOD_POSITION)),
        ),
    ) 
開發者ID:pybel,項目名稱:pybel,代碼行數:18,代碼來源:protein_modification.py

示例3: to_railroad

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def to_railroad(
    element: pyparsing.ParserElement,
    diagram_kwargs: dict = {},
    vertical: Union[int, bool] = 5,
) -> List[NamedDiagram]:
    """
    Convert a pyparsing element tree into a list of diagrams. This is the recommended entrypoint to diagram
    creation if you want to access the Railroad tree before it is converted to HTML
    :param diagram_kwargs: kwargs to pass to the Diagram() constructor
    """
    # Convert the whole tree underneath the root
    lookup = ConverterState(diagram_kwargs=diagram_kwargs)
    _to_diagram_element(element, lookup=lookup, parent=None, vertical=vertical)

    root_id = id(element)
    # Convert the root if it hasn't been already
    if root_id in lookup.first:
        lookup.first[root_id].mark_for_extraction(root_id, lookup, force=True)

    # Now that we're finished, we can convert from intermediate structures into Railroad elements
    resolved = [resolve_partial(partial) for partial in lookup.diagrams.values()]
    return sorted(resolved, key=lambda diag: diag.index) 
開發者ID:pyparsing,項目名稱:pyparsing,代碼行數:24,代碼來源:__init__.py

示例4: __init__

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def __init__(
        self,
        element: pyparsing.ParserElement,
        converted: EditablePartial,
        parent: EditablePartial,
        number: int,
        name: str = None,
        index: Optional[int] = None,
    ):
        #: The pyparsing element that this represents
        self.element = element  # type: pyparsing.ParserElement
        #: The name of the element
        self.name = name  # type: str
        #: The output Railroad element in an unconverted state
        self.converted = converted  # type: EditablePartial
        #: The parent Railroad element, which we store so that we can extract this if it's duplicated
        self.parent = parent  # type: EditablePartial
        #: The order in which we found this element, used for sorting diagrams if this is extracted into a diagram
        self.number = number  # type: int
        #: The index of this inside its parent
        self.parent_index = index  # type: Optional[int]
        #: If true, we should extract this out into a subdiagram
        self.extract = False  # type: bool
        #: If true, all of this element's chilren have been filled out
        self.complete = False  # type: bool 
開發者ID:pyparsing,項目名稱:pyparsing,代碼行數:27,代碼來源:__init__.py

示例5: matcher_element

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def matcher_element(self):
        """
        Lazily initialised `pyparsing` ``ParserElement`` used to match speech to
        expansions. It will also set ``current_match`` values.

        :returns: pyparsing.ParserElement
        """
        if not self._matcher_element:
            element = self._make_matcher_element()
            self._matcher_element = element
        else:
            element = self._matcher_element
        return element 
開發者ID:Danesprite,項目名稱:pyjsgf,代碼行數:15,代碼來源:expansions.py

示例6: __init__

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def __init__(self, language: ParserElement, streamline: bool = False) -> None:
        """Build a parser wrapper using a PyParsing language.

        :param language: The PyParsing language to use
        :param streamline: Should the language be streamlined on instantiation?
        """
        self.language = language

        #: The parser holds an internal state of the current line
        self._line_number = 0

        if streamline:
            self.streamline() 
開發者ID:pybel,項目名稱:pybel,代碼行數:15,代碼來源:baseparser.py

示例7: get_fragment_language

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def get_fragment_language() -> ParserElement:
    """Build a protein fragment parser."""
    _fragment_value_inner = fragment_range | missing_fragment(FRAGMENT_MISSING)
    _fragment_value = _fragment_value_inner | And([Suppress('"'), _fragment_value_inner, Suppress('"')])
    parser_element = fragment_tag + nest(_fragment_value + Optional(WCW + quote(FRAGMENT_DESCRIPTION)))
    return parser_element 
開發者ID:pybel,項目名稱:pybel,代碼行數:8,代碼來源:fragment.py

示例8: get_truncation_language

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def get_truncation_language() -> ParserElement:
    """Build a parser for protein truncations."""
    l1 = truncation_tag + nest(amino_acid(AMINO_ACID) + ppc.integer(TRUNCATION_POSITION))
    l1.setParseAction(_handle_trunc)
    l2 = truncation_tag + nest(ppc.integer(TRUNCATION_POSITION))
    l2.setParseAction(_handle_trunc_legacy)
    return l1 | l2 
開發者ID:pybel,項目名稱:pybel,代碼行數:9,代碼來源:truncation.py

示例9: get_gene_modification_language

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def get_gene_modification_language(concept_qualified: ParserElement) -> ParserElement:
    """Build a gene modification parser."""
    concept = MatchFirst([
        concept_qualified,
        gmod_default_ns,
    ])
    return gmod_tag + nest(Group(concept)(CONCEPT)) 
開發者ID:pybel,項目名稱:pybel,代碼行數:9,代碼來源:gene_modification.py

示例10: get_protein_substitution_language

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def get_protein_substitution_language() -> ParserElement:
    """Build a protein substitution parser."""
    parser_element = psub_tag + nest(
        amino_acid(PSUB_REFERENCE),
        ppc.integer(PSUB_POSITION),
        amino_acid(PSUB_VARIANT),
    )
    parser_element.setParseAction(_handle_psub)
    return parser_element 
開發者ID:pybel,項目名稱:pybel,代碼行數:11,代碼來源:protein_substitution.py

示例11: get_hgvs_language

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def get_hgvs_language() -> ParserElement:
    """Build a HGVS :class:`pyparsing.ParseElement`."""
    hgvs = (variant_characters | quote)(HGVS)
    language = variant_tags + nest(hgvs)
    return language 
開發者ID:pybel,項目名稱:pybel,代碼行數:7,代碼來源:variant.py

示例12: get_location_language

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def get_location_language(identifier: ParserElement) -> ParserElement:
    """Build a location parser."""
    return Group(location_tag + nest(identifier))(LOCATION) 
開發者ID:pybel,項目名稱:pybel,代碼行數:5,代碼來源:location.py

示例13: _worth_extracting

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def _worth_extracting(element: pyparsing.ParserElement) -> bool:
    """
    Returns true if this element is worth having its own sub-diagram. Simply, if any of its children
    themselves have children, then its complex enough to extract
    """
    children = element.recurse()
    return any(
        [hasattr(child, "expr") or hasattr(child, "exprs") for child in children]
    ) 
開發者ID:pyparsing,項目名稱:pyparsing,代碼行數:11,代碼來源:__init__.py

示例14: flatten_pyparsing_exprs

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def flatten_pyparsing_exprs(expr):
    exprs = set()
    for child in expr.exprs:
        if isinstance(child, (Literal, six.string_types)):
            exprs.add(str(child).strip('"'))
        elif isinstance(child, (MatchFirst, ParseExpression, ParserElement)):
            exprs.update(flatten_pyparsing_exprs(child))
    return exprs 
開發者ID:sarugaku,項目名稱:requirementslib,代碼行數:10,代碼來源:strategies.py

示例15: match

# 需要導入模塊: import pyparsing [as 別名]
# 或者: from pyparsing import ParserElement [as 別名]
def match(cmp_value, spec):
    """Match a given value to a given spec DSL.

    This uses the grammar defined by make_grammar()

    :param cmp_value: Value to be checked for match.
    :param spec: The comparison specification string, for example ``">= 70"``
                 or ``"s== string_value"``. See ``make_grammar()`` for examples
                 of a specification string.
    :returns: True if cmp_value is a match for spec. False otherwise.
    """
    expr = make_grammar()
    try:
        # As of 2018-01-29 documentation on parseString()
        # https://pythonhosted.org/pyparsing/pyparsing.ParserElement-class.html#parseString
        #
        # parseString() will take our specification string, for example "< 6"
        # and convert it into a list of ['<', "6"]
        tree = expr.parseString(spec)
    except pyparsing.ParseException:
        # If an exception then we will just check if the value matches the spec
        tree = [spec]
    if len(tree) == 1:
        return tree[0] == cmp_value

    # tree[0] will contain a string representation of a comparison operation
    # such as '>=', we then convert that string to a comparison function
    compare_func = op_methods[tree[0]]
    return compare_func(cmp_value, *tree[1:]) 
開發者ID:openstack,項目名稱:oslo.utils,代碼行數:31,代碼來源:specs_matcher.py


注:本文中的pyparsing.ParserElement方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。