本文整理汇总了Python中xml.sax.xmlreader.Locator方法的典型用法代码示例。如果您正苦于以下问题:Python xmlreader.Locator方法的具体用法?Python xmlreader.Locator怎么用?Python xmlreader.Locator使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类xml.sax.xmlreader
的用法示例。
在下文中一共展示了xmlreader.Locator方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: reset
# 需要导入模块: from xml.sax import xmlreader [as 别名]
# 或者: from xml.sax.xmlreader import Locator [as 别名]
def reset(self):
if self._namespaces:
self._parser = expat.ParserCreate(self._source.getEncoding(), " ",
intern=self._interning)
self._parser.namespace_prefixes = 1
self._parser.StartElementHandler = self.start_element_ns
self._parser.EndElementHandler = self.end_element_ns
else:
self._parser = expat.ParserCreate(self._source.getEncoding(),
intern = self._interning)
self._parser.StartElementHandler = self.start_element
self._parser.EndElementHandler = self.end_element
self._reset_cont_handler()
self._parser.UnparsedEntityDeclHandler = self.unparsed_entity_decl
self._parser.NotationDeclHandler = self.notation_decl
self._parser.StartNamespaceDeclHandler = self.start_namespace_decl
self._parser.EndNamespaceDeclHandler = self.end_namespace_decl
self._decl_handler_prop = None
if self._lex_handler_prop:
self._reset_lex_handler_prop()
# self._parser.DefaultHandler =
# self._parser.DefaultHandlerExpand =
# self._parser.NotStandaloneHandler =
self._parser.ExternalEntityRefHandler = self.external_entity_ref
try:
self._parser.SkippedEntityHandler = self.skipped_entity_handler
except AttributeError:
# This pyexpat does not support SkippedEntity
pass
self._parser.SetParamEntityParsing(
expat.XML_PARAM_ENTITY_PARSING_UNLESS_STANDALONE)
self._parsing = 0
self._entity_stack = []
# Locator methods
示例2: __init__
# 需要导入模块: from xml.sax import xmlreader [as 别名]
# 或者: from xml.sax.xmlreader import Locator [as 别名]
def __init__(self, encoding=None):
self.categories = {}
self._encoding = encoding
self._state = self._STATE_OutsideAiml
self._version = ""
self._namespace = ""
self._forwardCompatibleMode = False
self._currentPattern = ""
self._currentThat = ""
self._currentTopic = ""
self._insideTopic = False
self._currentUnknown = "" # the name of the current unknown element
# 在类别中发生分析错误时,将其设置为true。
self._skipCurrentCategory = False
# 统计特定AIML文档中解析错误的数量。用getNumErrors()查询。 如果为0,则文档符合AIML。
self._numParseErrors = 0
# TODO: 根据版本号选择合适的validInfo表。
self._validInfo = self._validationInfo101
# 这个bool值栈在解析<condition>元素中的<li>元素时,用来跟踪是否已经找到了一个无属性的“default”<li>元素。
# 每个<condition>元素中只允许有一个默认的<li>。 我们需要一个栈来正确处理嵌套的<condition>标签。
self._foundDefaultLiStack = []
# 这个字符串堆栈表示当前的空白处理行为应该是什么。堆栈中的每个字符串都是"default" 或"preserve"。
# 当遇到一个新的AIML元素时,根据元素的“xml:space”属性的值(如果没有,堆栈顶部被再次push),一个新的字符串被压入栈中。
# 一个元素结束时,从堆栈中弹出一个对象。
self._whitespaceBehaviorStack = ["default"]
self._elemStack = []
self._locator = Locator()
self.setDocumentLocator(self._locator)