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"
感謝您的輸入。我設法得到我想要的$ xmlnod.OuterXml。 – MarcusMaximus