本文整理汇总了Python中sre_constants.BRANCH属性的典型用法代码示例。如果您正苦于以下问题:Python sre_constants.BRANCH属性的具体用法?Python sre_constants.BRANCH怎么用?Python sre_constants.BRANCH使用的例子?那么恭喜您, 这里精选的属性代码示例或许可以为您提供帮助。您也可以进一步了解该属性所在类sre_constants
的用法示例。
在下文中一共展示了sre_constants.BRANCH属性的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: __init__
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def __init__(self, lexicon, flags=0):
from sre_constants import BRANCH, SUBPATTERN
if isinstance(flags, RegexFlag):
flags = flags.value
self.lexicon = lexicon
# combine phrases into a compound pattern
p = []
s = sre_parse.Pattern()
s.flags = flags
for phrase, action in lexicon:
gid = s.opengroup()
p.append(sre_parse.SubPattern(s, [
(SUBPATTERN, (gid, 0, 0, sre_parse.parse(phrase, flags))),
]))
s.closegroup(gid, p[-1])
p = sre_parse.SubPattern(s, [(BRANCH, (None, p))])
self.scanner = sre_compile.compile(p)
示例2: mutually_inclusive_alternation_helper
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def mutually_inclusive_alternation_helper(node, nested_quantifier):
if not node.children:
return False
nested_quantifier = (
nested_quantifier
or (node.op in sre_parse._REPEATCODES and large_repeat(node))
)
inclusive_alternation = False
if node.op is sre_constants.BRANCH:
inclusive_alternation = inclusive_alternation_branch(node)
return any(
(nested_quantifier and inclusive_alternation)
or mutually_inclusive_alternation_helper(child, nested_quantifier)
for child in node.children
)
示例3: __init__
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def __init__(self, lexicon, flags=0):
from sre_constants import BRANCH, SUBPATTERN
self.lexicon = lexicon
# combine phrases into a compound pattern
p = []
s = sre_parse.Pattern()
s.flags = flags
for phrase, action in lexicon:
p.append(sre_parse.SubPattern(s, [
(SUBPATTERN, (len(p)+1, sre_parse.parse(phrase, flags))),
]))
s.groups = len(p)+1
p = sre_parse.SubPattern(s, [(BRANCH, (None, p))])
self.scanner = sre_compile.compile(p)
示例4: __init__
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def __init__(self, lexicon, flags=0):
from sre_constants import BRANCH, SUBPATTERN
self.lexicon = lexicon
# combine phrases into a compound pattern
p = []
s = sre_parse.Pattern()
s.flags = flags
for phrase, action in lexicon:
gid = s.opengroup()
p.append(sre_parse.SubPattern(s, [
(SUBPATTERN, (gid, sre_parse.parse(phrase, flags))),
]))
s.closegroup(gid, p[-1])
p = sre_parse.SubPattern(s, [(BRANCH, (None, p))])
self.scanner = sre_compile.compile(p)
示例5: _make_match_string_from_pattern
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def _make_match_string_from_pattern(parsetree, makebad=False, groups=None):
collect = []
if groups is None:
groups = {}
for op, val in parsetree:
if op is sre_constants.LITERAL:
if makebad:
collect.append(chr((val ^ 4) & 0xFF)) # flip bit 4
if random.randint(0,9) == 0:
makebad = False # don't error everything
else:
collect.append(chr(val))
elif op is sre_constants.CATEGORY:
collect.append(get_substitute(val, makebad))
elif op is sre_constants.IN:
if val[0][0] is sre_constants.CATEGORY:
collect.append(_make_match_string_from_pattern(val, False, groups))
else:
collect.append(chr(random.choice(val)[1]))
elif op is sre_constants.BRANCH:
collect.append(_make_match_string_from_pattern(val[1][random.randint(0,1)], False, groups))
elif op is sre_constants.SUBPATTERN:
string = _make_match_string_from_pattern(val[1], False, groups)
groups[val[0]] = string
collect.append(string)
elif op is sre_constants.MAX_REPEAT or op is sre_constants.MIN_REPEAT:
for i in xrange(random.randint(val[0], min(val[1], 10))):
collect.append(_make_match_string_from_pattern(val[2], False, groups))
elif op is sre_constants.ANY:
collect.append(random.choice(ANYCHAR))
elif op is sre_constants.GROUPREF:
collect.append(groups[val])
elif op is sre_constants.AT:
pass # ignore anchors
else:
raise UnhandledOpError("Unhandled RE op: %r" % (op,))
if makebad: # in case it didn't get done yet.
collect.insert(random.randrange(0, len(collect)), random.choice(ascii.printable))
return "".join(collect)
示例6: __init__
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def __init__(self, lexicon, flags=0):
from sre_constants import BRANCH, SUBPATTERN
self.lexicon = lexicon
# combine phrases into a compound pattern
p = []
s = sre_parse.Pattern()
s.flags = flags
for phrase, action in lexicon:
p.append(sre_parse.SubPattern(s, [
(SUBPATTERN, (len(p)+1, sre_parse.parse(phrase, flags))),
]))
s.groups = len(p)+1
p = sre_parse.SubPattern(s, [(BRANCH, (None, p))])
self.scanner = sre_compile.compile(p)
示例7: build_op_tree
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def build_op_tree(node, subpattern):
for op, av in subpattern.data:
args = []
subpatterns = []
if op is sre_constants.BRANCH:
for a in av[1]:
subpatterns.append(a)
elif op is sre_constants.GROUPREF_EXISTS:
condgroup, item_yes, item_no = av
subpatterns.append(item_yes)
if item_no:
subpatterns.append(item_no)
elif isinstance(av, (tuple, list)):
for a in av:
if isinstance(a, sre_parse.SubPattern):
subpatterns.append(a)
else:
args.append(a)
else:
args.append(av)
new_node = OpNode(op, tuple(args))
for sp in subpatterns:
build_op_tree(new_node, sp)
node.children.append(new_node)
示例8: __init__
# 需要导入模块: import sre_constants [as 别名]
# 或者: from sre_constants import BRANCH [as 别名]
def __init__(self, pattern, flags=0, charset=CHARSET, max_count=None):
# If the RE module cannot compile it, we give up quickly
self.matcher = re.compile(r'(?:%s)\Z' % pattern, flags)
if not flags & re.DOTALL:
charset = ''.join(c for c in charset if c != '\n')
self.charset = charset
self.named_group_lookup = self.matcher.groupindex
if flags & re.IGNORECASE:
raise ParseError('Flag "i" not supported. https://github.com/google/sre_yield/issues/4')
elif flags & re.UNICODE:
raise ParseError('Flag "u" not supported. https://github.com/google/sre_yield/issues/3')
elif flags & re.LOCALE:
raise ParseError('Flag "l" not supported. https://github.com/google/sre_yield/issues/5')
if max_count is None:
self.max_count = MAX_REPEAT_COUNT
else:
self.max_count = max_count
self.has_groupref = False
# Configure the parser backends
self.backends = {
sre_constants.LITERAL: lambda y: [chr(y)],
sre_constants.RANGE: lambda l, h: [chr(c) for c in range(l, h+1)],
sre_constants.SUBPATTERN: self.maybe_save,
sre_constants.BRANCH: self.branch_values,
sre_constants.MIN_REPEAT: self.max_repeat_values,
sre_constants.MAX_REPEAT: self.max_repeat_values,
sre_constants.AT: self.empty_list,
sre_constants.ASSERT: self.empty_list,
sre_constants.ASSERT_NOT: self.empty_list,
sre_constants.ANY:
lambda _: self.in_values(((sre_constants.NEGATE,),)),
sre_constants.IN: self.in_values,
sre_constants.NOT_LITERAL: self.not_literal,
sre_constants.CATEGORY: self.category,
sre_constants.GROUPREF: self.groupref,
}
# Now build a generator that knows all possible patterns
self.raw = self.sub_values(sre_parse.parse(pattern, flags))
# Configure this class instance to know about that result
self.length = self.raw.__len__()