2017-04-12 82 views
0

我想弄清楚如何從我從PowerShell中的Web服務接收到的XML數據中提取數據。我也想輸出它作爲一個XML文件。提取XML數據並保存爲XML文件

我使用Invoke-WebRequest保存文件使用-Outfile,但我不希望所有的肥皂信封數據。從下面的示例數據中,我需要的是XML格式的<Visit_Requests>中的數據,稍後將使用SSIS將其導入到數據庫中。

<?xml version="1.0" encoding="utf-8"?> 
<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> 
    <soap:Body> 
     <getData_Visit_RequestsResponse xmlns="http://example.com/"> 
      <getData_Visit_RequestsResult RequestDate="10 Apr 2017" NumberOfRecordsReturned="54" MaximumNumberOfRecordsReturned="10000" RecordsStartAtRowNumber="1" PagingImplemented="true" ErrorMessage=""> 
       <Visit_Requests> 
        <Visit_Request> 
         <Visit_ID>3907</Visit_ID> 
         <Building_Name>Building HHH</Building_Name> 
         <Level_Name>North Wing</Level_Name> 
         <Contact_Name>Bill Bloggs</Contact_Name> 
        </Visit_Request> 
        <Visit_Request> 
         <Visit_ID>3904</Visit_ID> 
         <Building_Name>Building GG</Building_Name> 
         <Level_Name>South Wing</Level_Name> 
         <Contact_Name>Mary Bloggs</Contact_Name> 
        </Visit_Request> 
        <Visit_Request> 
         <Visit_ID>3970</Visit_ID> 
         <Building_Name>Building VV</Building_Name> 
         <Level_Name>East Wing</Level_Name> 
         <Contact_Name>Bob Bloggs</Contact_Name> 
        </Visit_Request> 
        <Visit_Request> 
         <Visit_ID>4707</Visit_ID> 
         <Building_Name>Building ZZ</Building_Name> 
         <Level_Name>West Wing</Level_Name> 
         <Contact_Name>Joe Bloggs</Contact_Name> 
        </Visit_Request> 
       </Visit_Requests> 
      </getData_Visit_RequestsResult> 
     </getData_Visit_RequestsResponse> 
    </soap:Body> 
</soap:Envelope> 

我試過使用this的方法,但沒有得到任何好處。我不斷收到錯誤

無法導入空節點

[System.Xml.XmlElement]不包含名爲 '保存'

方法我已經嘗試使用

將內容寫入另一個文件

但是所有寫入的都是PowerShell對象{Visit_Request, Visit_Request...}

代碼爲獲得我想要的結果使用$xmlnode.OuterXml

(New-Object System.Net.WebClient).Proxy.Credentials = [System.Net.CredentialCache]::DefaultNetworkCredentials 

[xml]$result = Invoke-WebRequest $uri -Method post -ContentType 'text/xml' -Body $SOAP_getData_Visit_Requests #-OutFile .\response.xml 

[System.Xml.XmlElement] $root = $result.get_DocumentElement() 
$xmlnode = $root.Body.getData_Visit_RequestsResponse.getData_Visit_RequestsResult.Visit_Requests 

$xmlnode.OuterXml| out-file ".\response.xml" 

回答

0

我猜你需要$xmlnode.InnerXml$xmlnod.OuterXml

請發佈您的代碼,因爲它不清楚您如何處理XML。

+0

感謝您的輸入。我設法得到我想要的$ xmlnod.OuterXml。 – MarcusMaximus