从xml中提取元素

时间:2014-08-29 21:01:37

标签: python xml django lxml

我需要从下面的xml中获取值。

我有一个Django Rest框架,它提供以下XML -

<root>
  <list-item>
    <jobmst_id>3493</jobmst_id>
    <jobmst_type>1</jobmst_type>
    <jobmst_prntid/>
    <jobmst_active>N</jobmst_active>
    <evntmst_id>
      <evntmst_id>1</evntmst_id>
      <evntmst_name>Daily                                                       </evntmst_name>
      <evntmst_desc/>
      <evntmst_owner>2</evntmst_owner>
      <evntmst_lstchgtm>2009-12-04 12:28:52</evntmst_lstchgtm>
      <evntmst_lstcmptm>2014-08-28 12:00:29</evntmst_lstcmptm>
      <evntmst_fromdt/>
      <evntmst_untildt>2012-12-31 00:00:00</evntmst_untildt>
      <evntmst_frcstdt>2012-12-31 00:00:00</evntmst_frcstdt>
      <evntmst_type>2</evntmst_type>
      <evntmst_subtype/>
      <evntmst_freq>1</evntmst_freq>
      <evntmst_crttm>2009-12-04 11:22:03</evntmst_crttm>
      <evntmst_totcnt/>
      <evntmst_public>Y</evntmst_public>
      <evntmst_months>YYYYYYYYYYYY</evntmst_months>
      <evntmst_weeks>NNNNN</evntmst_weeks>
      <evntmst_monthdays>YYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYY</evntmst_monthdays>
      <evntmst_weekdays>YYYYYYY</evntmst_weekdays>
      <evntmst_offset>0</evntmst_offset>
      <evntmst_intsect>N</evntmst_intsect>
      <evntmst_occur>0</evntmst_occur>
      <evntmst_timeframe>0</evntmst_timeframe>
      <evntmst_calendar>0</evntmst_calendar>
      <evntmst_fiscal>0</evntmst_fiscal>
    </evntmst_id>
    <jobmst_evntoffset/>
    <jobmst_name>SWIFT</jobmst_name>
    <jobmst_mode>0</jobmst_mode>
    <jobmst_owner>
      <owner_id>128</owner_id>
      <owner_type>2</owner_type>
      <owner_name>SWIFT                         </owner_name>
      <owner_allagents>Y</owner_allagents>
    </jobmst_owner>
    <jobmst_desc/>
    <jobmst_crttm>2009-04-24 14:17:56</jobmst_crttm>
    <jobdtl_id>
      <jobdtl_id>3493</jobdtl_id>
      <jobdtl_cmd/>
      <jobdtl_envfile/>
      <jobdtl_retnsn>180</jobdtl_retnsn>
      <jobdtl_allowadhoc>Y</jobdtl_allowadhoc>
      <jobdtl_waitop>N</jobdtl_waitop>
      <jobdtl_fromdt>1899-12-30 00:00:00</jobdtl_fromdt>
      <jobdtl_untildt>1899-12-30 00:00:00</jobdtl_untildt>
      <jobdtl_fromtm/>
      <jobdtl_untiltm/>
      <jobdtl_proxy>
        <usrmst_id>4</usrmst_id>
        <usrmst_domain>CPPIB               </usrmst_domain>
        <usrmst_name>svc_tidal</usrmst_name>
        <usrmst_fullname>Tidal User</usrmst_fullname>
        <usrmst_desc/>
        <usrmst_phoneno/>
        <usrmst_pagerno/>
        <usrmst_email/>
        <usrmst_emailtype>0</usrmst_emailtype>
        <secmst_id>1</secmst_id>
        <lngmst_id>1</lngmst_id>
        <usrmst_password>@JrL(OOLO8RSAWKX</usrmst_password>
        <usrmst_externid/>
        <usrmst_suser>Y</usrmst_suser>
        <usrmst_lstchgtm>2013-05-30 12:18:13</usrmst_lstchgtm>
        <usrmst_sappassword/>
        <usrmst_pspassword/>
        <usrmst_aspassword/>
        <usrmst_orapassword/>
        <usrmst_wingroup>N</usrmst_wingroup>
      </jobdtl_proxy>
      <jobdtl_proxy2/>
      <jobdtl_interval/>
      <jobdtl_intervalcnt/>
      <jobdtl_unit/>
      <jobdtl_duration>55826</jobdtl_duration>
      <jobdtl_concur>1</jobdtl_concur>
      <jobdtl_priority>50</jobdtl_priority>
      <jobdtl_minrun>60</jobdtl_minrun>
      <jobdtl_maxrun>60</jobdtl_maxrun>
      <jobdtl_failalarm/>
      <nodmst_id/>
      <nodlstmst_id>
        <nodlstmst_id>27</nodlstmst_id>
        <nodlstmst_name>OPS_SharedWIN                 </nodlstmst_name>
        <nodlstmst_desc/>
        <nodlstmst_type>1</nodlstmst_type>
        <nodlstmst_prntid/>
        <nodlstmst_seq/>
        <nodlstmst_ostype>1</nodlstmst_ostype>
        <nodlstmst_lastused/>
        <nodlstmst_lstchgtm>2014-07-23 15:31:37</nodlstmst_lstchgtm>
        <servicemst_id/>
      </nodlstmst_id>
      <jobdtl_inhevent>N</jobdtl_inhevent>
      <jobdtl_inhoptions>N</jobdtl_inhoptions>
      <jobdtl_inhagent>N</jobdtl_inhagent>
      <jobdtl_inhrepeat>N</jobdtl_inhrepeat>
      <jobdtl_inhtime>N</jobdtl_inhtime>
      <jobdtl_timewin>0</jobdtl_timewin>
      <jobdtl_saveoutput>Y</jobdtl_saveoutput>
      <jobdtl_outputname/>
      <jobdtl_trackmethod>1</jobdtl_trackmethod>
      <jobdtl_trackcmd/>
      <jobdtl_deplogic>1</jobdtl_deplogic>
      <jobdtl_rerun/>
      <jobdtl_params/>
      <jobdtl_sapcount/>
      <jobdtl_normalexit>0</jobdtl_normalexit>
      <jobdtl_normalrange>0</jobdtl_normalrange>
      <jobdtl_normalop>1</jobdtl_normalop>
      <jobdtl_deprerun>N</jobdtl_deprerun>
      <jobdtl_carryover>1</jobdtl_carryover>
      <jobdtl_psjob/>
      <jobdtl_savelogonly>N</jobdtl_savelogonly>
      <jobdtl_trxid>0</jobdtl_trxid>
      <jobdtl_rerunok>Y</jobdtl_rerunok>
      <jobdtl_workdir/>
      <jobdtl_extinfo/>
      <servicemst_id/>
      <jobdtl_estmethod>1</jobdtl_estmethod>
      <jobdtl_nearoutage>3</jobdtl_nearoutage>
      <jobdtl_trackcl/>
      <jobdtl_statuscl/>
      <jobdtl_abrtonclderr/>
      <jobdtl_estdurexclude>4</jobdtl_estdurexclude>
    </jobdtl_id>
    <jobmst_lstchgtm>2009-04-24 14:19:02</jobmst_lstchgtm>
    <jobmst_runbook/>
    <jobcls_id/>
    <jobmst_prntname/>
    <jobmst_alias>3493A     </jobmst_alias>
    <jobmst_dirty> </jobmst_dirty>
    <job_dependencies/>
    <job_events/>
  </list-item>
</root>

我正在编写另一个需要获取<jobmst_id></jobmst_id>元素值的应用程序,因为我想在保存时将该值用作文件名。

我已将保存部分缩小,但我不确定如何获取元素值。

            fullsrcurl = self.srcjson + '?format=xml&jobname=' + job
            fulltrgurl = self.targetjson + '?format=xml&jobname=' + job
            file = urllib2.urlopen(fullsrcurl)
            doc = etree.parse(file)
            data = etree.tostring(doc, pretty_print=True)       

            file = 'c:\\temp\\deployments\\DEV\\test.xml'
            xmlsave = open(file, 'w')
            xmlsave.write(data)
            xmlsave.close

1 个答案:

答案 0 :(得分:1)

您可以使用记录的here

中的XPath语法
root = ET.fromstring(data)
jobmst_id_tag = root.find('./list-item/jobmst_id')
jobmst_id_value = jobmst_id_tag.text
print jobmst_id_value

这给出了:

3493