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


Python etree.parse方法代碼示例

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


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

示例1: list

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def list():
        """ get list of all collection entries """

        cols_elem = ET.Element('collections')
        for col in Col.objects.all():
            path = os.path.join('data', 'collections', col.name)
            if not os.path.exists(path):
                logging.error('Collection has inconstancy : %s !!' % col.name)
                continue
            files = glob.glob(os.path.join(path, '*'))
            for _file in files:
                payload = ET.parse(_file)
                for child in payload.getroot():
                    if child.tag == 'metadata':
                        cols_elem.append(child)
        return cols_elem 
開發者ID:CiscoDevNet,項目名稱:yang-explorer,代碼行數:18,代碼來源:collection.py

示例2: project_status_requests

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def project_status_requests(self, request_type, filter_function=None):
        requests = []
        for status in self.project_status(None, status=False):
            for request in status.findall(f'{request_type}_requests/request'):
                updated_at = dateutil.parser.parse(request.get('updated'), ignoretz=True)
                updated_delta = datetime.utcnow() - updated_at
                if updated_delta.total_seconds() < 0 * 60:
                    # Allow for dashboard to update caches by not considering
                    # requests whose state has changed in the last 5 minutes.
                    continue

                if filter_function and not filter_function(request, updated_delta):
                    continue

                requests.append(str(request.get('id')))

        return requests 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:19,代碼來源:stagingapi.py

示例3: ensure_staging_archs

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def ensure_staging_archs(self, project):
        meta = ET.parse(http_GET(self.project_meta_url(project)))
        repository = meta.find('repository[@name="{}"]'.format(self.cmain_repo))

        changed = False
        for arch in self.cstaging_archs:
            if not repository.xpath('./arch[text()="{}"]'.format(arch)):
                elm = ET.SubElement(repository, 'arch')
                elm.text = arch
                changed = True

        if not changed:
            return

        meta = ET.tostring(meta)
        http_PUT(self.project_meta_url(project), data=meta) 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:18,代碼來源:stagingapi.py

示例4: package_source_hash

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def package_source_hash(apiurl, project, package, revision=None):
    query = {}
    if revision:
        query['rev'] = revision

    # Will not catch packages that previous had a link, but no longer do.
    if package_source_link_copy(apiurl, project, package):
        query['expand'] = 1

    try:
        url = makeurl(apiurl, ['source', project, package], query)
        root = ETL.parse(http_GET(url)).getroot()
    except HTTPError as e:
        if e.code == 400 or e.code == 404:
            # 400: revision not found, 404: package not found.
            return None

        raise e

    if revision and root.find('error') is not None:
        # OBS returns XML error instead of HTTP 404 if revision not found.
        return None

    from osclib.util import sha1_short
    return sha1_short(root.xpath('entry[@name!="_link"]/@md5')) 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:27,代碼來源:core.py

示例5: find_via_stagingapi

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def find_via_stagingapi(self, pkgs):
        """
        Search for all various mutations and return list of SR#s. Use
        and instance of StagingAPI to direct the search, this makes
        sure that the SR# are inside a staging project.
        :param pkgs: mesh of argumets to search for

        This function is only called for its side effect.
        """

        url = self.api.makeurl(['staging', self.api.project, 'staging_projects'], { 'requests': 1 })
        status = ET.parse(self.api.retried_GET(url)).getroot()

        for p in pkgs:
            found = False
            for staging in status.findall('staging_project'):
                for request in staging.findall('staged_requests/request'):
                    if request.get('package') == p or request.get('id') == p:
                        self.srs[int(request.get('id'))] = {'staging': staging.get('name')}
                        found = True
                        break
            if not found:
                raise oscerr.WrongArgs('No SR# found for: {}'.format(p)) 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:25,代碼來源:request_finder.py

示例6: getlabel

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def getlabel(self,xmlPath):
        tree = ET.parse(xmlPath)
        root = tree.getroot()
        print(root[6][0].text) 
開發者ID:AmeyaWagh,項目名稱:Traffic_sign_detection_YOLO,代碼行數:6,代碼來源:YOLOtest.py

示例7: __init__

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def __init__(self, file_path):
        tree = etree.parse(file_path)
        self.__root = xpath(tree.getroot(), './tei:text/tei:body', self.ns)[0] 
開發者ID:rafasashi,項目名稱:razzy-spinner,代碼行數:5,代碼來源:mte.py

示例8: get_session_config

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def get_session_config(username):
    session = ET.Element('session')
    user = ET.Element('username')
    user.text = username
    session.append(user)
    if username != '':
        # Pass global static configuration data
        _global = ET.parse(os.path.join('static', 'global-config.xml')).getroot()
        session.append(_global)
    return session 
開發者ID:CiscoDevNet,項目名稱:yang-explorer,代碼行數:12,代碼來源:views.py

示例9: __init__

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def __init__(self, filename):
        self.modules = {}
        logging.debug('Parsing %s !!' % filename)
        root = ET.parse(filename).getroot()

        for child in root:
            module = DYModule(child)
            self.modules[module.name] = module

        for name in self.modules:
            module = self.modules[name]
            for imp in module.imports:
                i_module = self.modules.get(imp, None)
                if i_module is None:
                    logging.warning('Dependent modules %s not found in dependency list !!' % imp)
                    continue
                if imp not in i_module.depends:
                    i_module.depends.append(name)

            for inc in module.includes:
                i_module = self.modules.get(inc, None)
                if i_module is None:
                    logging.warning('Included modules %s not found in dependency list !!' % inc)
                    continue
                if inc not in i_module.depends:
                    i_module.depends.append(name) 
開發者ID:CiscoDevNet,項目名稱:yang-explorer,代碼行數:28,代碼來源:dygraph.py

示例10: __init__

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def __init__(self, filename):
        self.filename = filename
        self.modulename = os.path.splitext(os.path.basename(filename))[0]
        if os.path.exists(filename):
            logging.debug('Parsing %s' % filename)
            try:
                self.cxml = ET.parse(filename)
            except:
                self.cxml = None
                logging.error('ET Failed to parse %s' % filename)
        else:
            self.cxml = None
            logging.error('File %s does not exists' % filename) 
開發者ID:CiscoDevNet,項目名稱:yang-explorer,代碼行數:15,代碼來源:cxml.py

示例11: check_arch

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def check_arch(self, project, repository, architecture):
        url = makeurl(self.apiurl, [
                      'build', project, repository, architecture], {'view': 'status'})
        root = ET.parse(http_GET(url)).getroot()
        if root.get('code') == 'finished':
            buildid = root.find('buildid')
            if buildid is not None:
                return buildid.text 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:10,代碼來源:rabbit-repoid.py

示例12: gather_isos

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def gather_isos(self, name, repository):
        url = self.api.makeurl(['published', name, repository, 'iso'])
        f = self.api.retried_GET(url)
        root = ET.parse(f).getroot()
        ret = []
        for entry in root.findall('entry'):
            if entry.get('name').endswith('iso'):
                ret.append(self.map_iso(name, entry.get('name')))
        return ret 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:11,代碼來源:rabbit-openqa.py

示例13: gather_buildid

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def gather_buildid(self, name, repository):
        url = self.api.makeurl(['published', name, repository], {'view': 'status'})
        f = self.api.retried_GET(url)
        id = ET.parse(f).getroot().find('buildid')
        if id is not None:
            return id.text 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:8,代碼來源:rabbit-openqa.py

示例14: build_summary

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def build_summary(self, project, repository):
        url = makeurl(self.apiurl, ['build', project, '_result'], { 'repository': repository, 'view': 'summary' })
        try:
            f = http_GET(url)
        except HTTPError as e:
            return { 'building': -1 }
        root = ET.parse(f).getroot()
        failed = 0
        unresolvable = 0
        building = 0
        succeeded = 0
        for result in root.findall('.//statuscount'):
            code = result.get('code')
            count = int(result.get('count'))
            if code == 'excluded' or code == 'disabled':
                continue # ignore
            if code == 'succeeded':
                succeeded += count
                continue
            if code == "failed":
                failed += count
                continue
            if code == "unresolvable":
                unresolvable += count
                continue
            building += count
            #print(code, file=sys.stderr)
        # let's count them as building
        if building > 0:
            building += unresolvable
            unresolvable = 0
        if building + failed + succeeded == 0:
            return {'building': -1}
        return { 'building': 1000 - int(building * 1000 / (building + failed + succeeded)),
                 'failed': failed,
                 'unresolvable': unresolvable } 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:38,代碼來源:generate.py

示例15: mirror

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import parse [as 別名]
def mirror(apiurl, project, repository, arch):
    """Call bs_mirrorfull script to mirror packages."""
    directory = os.path.join(CACHEDIR, project, repository, arch)

    if not os.path.exists(directory):
        os.makedirs(directory)

    meta = ETL.parse(http_GET('{}/public/source/{}/_meta'.format(apiurl, project))).getroot()
    repotag = meta.xpath("/project/repository[@name='{}']".format(repository))[0]
    if arch not in repotag.xpath("./arch/text()"):
        # Arch not in this project, skip mirroring
        return directory

    download = repotag.xpath("./download[@arch='{}']".format(arch))
    if download is not None and len(download) > 0:
        if len(download) > 1:
            raise Exception('Multiple download urls unsupported')
        repotype = download[0].get('repotype')
        if repotype != 'rpmmd':
            raise Exception('repotype {} not supported'.format(repotype))
        return mirrorRepomd(directory, download[0].get('url'))

    script = os.path.join(SCRIPT_PATH, '..', 'bs_mirrorfull')
    path = '/'.join((project, repository, arch))
    logger.info('mirroring {}'.format(path))
    url = '{}/public/build/{}'.format(apiurl, path)
    p = subprocess.run(['perl', script, '--nodebug', url, directory])

    if p.returncode:
        raise Exception('failed to mirror {}'.format(path))

    return directory 
開發者ID:openSUSE,項目名稱:openSUSE-release-tools,代碼行數:34,代碼來源:repochecks.py


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