本文整理匯總了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)