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


Python expat.ExpatError方法代碼示例

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


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

示例1: _handle_result

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def _handle_result(self, res):
        res.encoding = "utf-8-sig"
        xml = res.text
        logger.debug("Response from WeChat API \n %s", xml)
        try:
            data = xmltodict.parse(xml)["xml"]
        except (xmltodict.ParsingInterrupted, ExpatError):
            # 解析 XML 失敗
            logger.debug("WeChat payment result xml parsing error", exc_info=True)
            return xml

        return_code = data["return_code"]
        return_msg = data.get("return_msg", data.get("retmsg"))
        result_code = data.get("result_code", data.get("retcode"))
        errcode = data.get("err_code")
        errmsg = data.get("err_code_des")
        if return_code != "SUCCESS" or result_code != "SUCCESS":
            # 返回狀態碼不為成功
            raise WeChatPayException(
                return_code, result_code, return_msg, errcode, errmsg, client=self, request=res.request, response=res,
            )
        return data 
開發者ID:wechatpy,項目名稱:wechatpy,代碼行數:24,代碼來源:__init__.py

示例2: __init__

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def __init__(self, response, _message=None):
        status = response.status
        reason = response.reason
        body = response.body.read()
        try:
            detail = XML(body).findtext("./messages/msg")
        except ParseError as err:
            detail = body
        message = "HTTP %d %s%s" % (
            status, reason, "" if detail is None else " -- %s" % detail)
        Exception.__init__(self, _message or message)
        self.status = status
        self.reason = reason
        self.headers = response.headers
        self.body = body
        self._response = response 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:18,代碼來源:binding.py

示例3: __init__

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def __init__(self, response, _message=None):
        status = response.status
        reason = response.reason
        body = (response.body.read()).decode()
        try:
            detail = XML(body).findtext("./messages/msg")
        except ParseError as err:
            detail = body
        message = "HTTP %d %s%s" % (
            status, reason, "" if detail is None else " -- %s" % detail)
        Exception.__init__(self, _message or message)
        self.status = status
        self.reason = reason
        self.headers = response.headers
        self.body = body
        self._response = response 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:18,代碼來源:binding.py

示例4: send

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def send(self, command, *args, **kwargs):
        """Generic method for executing an XML-RPC *command*. *args* and
        *kwargs* are the arguments and parameters needed by the command.
        """
        args = list(args)
        if kwargs:
            args.append(kwargs)

        method = self.proxy
        for elt in command.split('.'):
            method = getattr(method, elt)

        try:
            return method(*args)
        except Fault as err:
            if err.faultCode == 121:
                return {}
            elif err.faultCode == 321:
                return []
            raise DokuWikiError(err)
        except ExpatError as err:
            if str(err) != ERR:
                raise DokuWikiError(err) 
開發者ID:fmenabe,項目名稱:python-dokuwiki,代碼行數:25,代碼來源:dokuwiki.py

示例5: set

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def set(self, page, content, **options):
        """Set/replace the *content* of *page*.

        Valid *options* are:

            * *sum*: (str) change summary
            * *minor*: (bool) whether this is a minor change
        """
        try:
            return self._dokuwiki.send('wiki.putPage', page, content, options)
        except ExpatError as err:
            # Sometime the first line of the XML response is blank which raise
            # the 'ExpatError' exception although the change has been done. This
            # allow to ignore the error.
            if str(err) != ERR:
                raise DokuWikiError(err) 
開發者ID:fmenabe,項目名稱:python-dokuwiki,代碼行數:18,代碼來源:dokuwiki.py

示例6: _upload_instances

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def _upload_instances(self, path):
        instances_count = 0
        dirs, not_in_use = default_storage.listdir(path)

        for instance_dir in dirs:
            instance_dir_path = os.path.join(path, instance_dir)
            i_dirs, files = default_storage.listdir(instance_dir_path)
            xml_file = None

            if 'submission.xml' in files:
                file_obj = default_storage.open(
                    os.path.join(instance_dir_path, 'submission.xml'))
                xml_file = file_obj

            if xml_file:
                try:
                    self._upload_instance(xml_file, instance_dir_path, files)
                except ExpatError:
                    continue
                except Exception:
                    pass
                else:
                    instances_count += 1

        return instances_count 
開發者ID:awemulya,項目名稱:kobo-predict,代碼行數:27,代碼來源:briefcase_client.py

示例7: CallFunction

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def CallFunction(self):
    """Calls the function via RPC."""
    if self._xmlrpc_proxy is None:
      return None

    rpc_call = getattr(self._xmlrpc_proxy, self._RPC_FUNCTION_NAME, None)
    if rpc_call is None:
      return None

    try:
      return rpc_call()  # pylint: disable=not-callable
    except (
        expat.ExpatError, SocketServer.socket.error,
        xmlrpclib.Fault) as exception:
      logger.warning('Unable to make RPC call with error: {0!s}'.format(
          exception))
      return None 
開發者ID:log2timeline,項目名稱:plaso,代碼行數:19,代碼來源:plaso_xmlrpc.py

示例8: _from_xml

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def _from_xml(self, datastring):
        if datastring is None:
            return None
        plurals = set(self.metadata.get('plurals', {}))
        try:
            node = etree.fromstring(datastring)
            root_tag = self._get_key(node.tag)
            links = self._get_links(root_tag, node)
            result = self._from_xml_node(node, plurals)
            if root_tag == constants.VIRTUAL_ROOT_KEY:
                return result
            return dict({root_tag: result}, **links)
        except Exception as e:
            parseError = False
            if (hasattr(etree, 'ParseError') and
                    isinstance(e, getattr(etree, 'ParseError'))):
                parseError = True
            elif isinstance(e, expat.ExpatError):
                parseError = True
            if parseError:
                msg = _("Cannot understand XML")
                raise exception.MalformedResponseBody(reason=msg)
            else:
                raise 
開發者ID:nttcom,項目名稱:eclcli,代碼行數:26,代碼來源:serializer.py

示例9: setOutputFile

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def setOutputFile(self):
        '''
        Initiates the xml file from the configuration.
        '''
        if (conf.xmlFile):
            try:
                self._outputFile = conf.xmlFile
                self.__root = None

                if os.path.exists(self._outputFile):
                    try:
                        self.__doc = xml.dom.minidom.parse(self._outputFile)
                        self.__root = self.__doc.childNodes[0]
                    except ExpatError:
                        self.__doc = Document()

                self._outputFP = codecs.open(self._outputFile, "w+", UNICODE_ENCODING)

                if self.__root is None:
                    self.__root = self.__doc.createElementNS(NAME_SPACE_ATTR, RESULTS_ELEM_NAME)
                    self.__root.setAttributeNode(self._createAttribute(XMLNS_ATTR, NAME_SPACE_ATTR))
                    self.__root.setAttributeNode(self._createAttribute(SCHEME_NAME_ATTR, SCHEME_NAME))
                    self.__doc.appendChild(self.__root)
            except IOError:
                raise SqlmapFilePathException("Wrong filename provided for saving the xml file: %s" % conf.xmlFile) 
開發者ID:krintoxi,項目名稱:NoobSec-Toolkit,代碼行數:27,代碼來源:xmldump.py

示例10: read_nfofile

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def read_nfofile(filename):
    if not xbmcvfs.exists(filename):
        return None
    with closing(xbmcvfs.File(filename)) as nfofile:
        try:
            return ET.parse(nfofile).getroot()
        except ParseError:
            pass
        # maybe it's all XML except the last line, like the wiki suggests for XML + URL
        nfofile.seek(0, 0)
        lines = nfofile.read().split('\n')
        while lines and not lines[-1].strip():
            del lines[-1] # Remove final blank lines
        if lines: # Remove the line that possibly contains the URL
            del lines[-1]
        if lines:
            try:
                return ET.XML('\n'.join(lines))
            except ParseError:
                pass 
開發者ID:rmrector,項目名稱:script.artwork.beef,代碼行數:22,代碼來源:nfofile.py

示例11: make_sparse_image

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def make_sparse_image(volume_name, output_path):
    '''Make a sparse disk image we can install a product to'''
    cmd = ['/usr/bin/hdiutil', 'create', '-size', '16g', '-fs', 'HFS+',
           '-volname', volume_name, '-type', 'SPARSE', '-plist', output_path]
    try:
        output = subprocess.check_output(cmd)
    except subprocess.CalledProcessError as err:
        print(err, file=sys.stderr)
        exit(-1)
    try:
        return read_plist_from_string(output)[0]
    except IndexError as err:
        print('Unexpected output from hdiutil: %s' % output, file=sys.stderr)
        exit(-1)
    except ExpatError as err:
        print('Malformed output from hdiutil: %s' % output, file=sys.stderr)
        print(err, file=sys.stderr)
        exit(-1) 
開發者ID:AlexanderWillner,項目名稱:runMacOSinVirtualBox,代碼行數:20,代碼來源:installinstallmacos.py

示例12: parse_server_metadata

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def parse_server_metadata(filename):
    '''Parses a softwareupdate server metadata file, looking for information
    of interest.
    Returns a dictionary containing title, version, and description.'''
    title = ''
    vers = ''
    try:
        md_plist = read_plist(filename)
    except (OSError, IOError, ExpatError) as err:
        print('Error reading %s: %s' % (filename, err), file=sys.stderr)
        return {}
    vers = md_plist.get('CFBundleShortVersionString', '')
    localization = md_plist.get('localization', {})
    preferred_localization = (localization.get('English') or
                              localization.get('en'))
    if preferred_localization:
        title = preferred_localization.get('title', '')

    metadata = {}
    metadata['title'] = title
    metadata['version'] = vers
    return metadata 
開發者ID:AlexanderWillner,項目名稱:runMacOSinVirtualBox,代碼行數:24,代碼來源:installinstallmacos.py

示例13: readXML

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def readXML(xmlfile, expectedRootTag=None):
    """
    Read in XML data from a file and parse into ElementTree. Optionally verify
    the root node is what we expect.

    @param xmlfile: file to read from
    @type xmlfile: C{File}
    @param expectedRootTag: root tag (qname) to test or C{None}
    @type expectedRootTag: C{str}
    @return: C{tuple} of C{ElementTree}, C{Element}
    """

    # Read in XML
    try:
        etree = XML.ElementTree(file=xmlfile)
    except XMLParseError, e:
        raise ValueError("Unable to parse file '%s' because: %s" % (xmlfile, e,)) 
開發者ID:apple,項目名稱:ccs-calendarserver,代碼行數:19,代碼來源:xmlutil.py

示例14: convert_result

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def convert_result(self, result):
        if self.conversion_method == "none" or "result" not in result:
            return result
        try:
            if self.conversion_method == "text":
                result["result"] = str(result["result"])
            elif self.conversion_method == "json":
                result["result"] = loads(result["result"])
            elif self.conversion_method == "xml":
                result["result"] = parse(result["result"])
        except (ExpatError, JSONDecodeError) as exc:
            result = {
                "success": False,
                "text_response": result,
                "error": f"Conversion to {self.conversion_method} failed",
                "exception": str(exc),
            }
        return result 
開發者ID:eNMS-automation,項目名稱:eNMS,代碼行數:20,代碼來源:automation.py

示例15: _get_properties

# 需要導入模塊: from xml.parsers import expat [as 別名]
# 或者: from xml.parsers.expat import ExpatError [as 別名]
def _get_properties(self):
        """Get the properties of the download center."""

        request_xml = """
        <App_DCGetDataToCreatePackageReq getListOfUsers="1"
            getListOfGroups="1" getCategories="1" getSubCategories="1"
            getPlatforms="1" getDownloadTypes="1" getProductVersions="1"
            getRecutNumbers="1" getVendors="1" getDownloadedPackageUsers="1"
            packageId="1" getServerTypes="1"/>
        """

        flag, response = self._cvpysdk_object.make_request(
            'POST', self._services['GET_DC_DATA'], request_xml
        )

        if flag:
            try:
                self._response = response.json()
            except ExpatError:
                raise SDKException('DownloadCenter', '101', response.text)
        else:
            response_string = self._update_response_(response.text)
            raise SDKException('Response', '101', response_string) 
開發者ID:CommvaultEngg,項目名稱:cvpysdk,代碼行數:25,代碼來源:download_center.py


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