2017-10-10 114 views
0

我正在使用XML包提取一些元數據。我找到了一個很好的解決方案來提取作者姓名:https://www.r-bloggers.com/microsoft-office-metadata-with-r/。使用代碼的第一行 我得到這個:使用R中的XML包提取文件中的修改日期

library(XML) 
doc <- xmlInternalTreeParse('<?xml version="1.0" encoding="UTF-8" standalone="yes"?> 
    <cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> 
     <dc:title>CHR-nr</dc:title> 
     <dc:subject/> 
     <dc:creator>XXXXXX</dc:creator> 
     <cp:keywords/> 
     <dc:description/> 
     <cp:lastModifiedBy>XXXXXX</cp:lastModifiedBy> 
     <cp:revision>1</cp:revision> 
     <cp:lastPrinted>2013-03-22T12:16:00Z</cp:lastPrinted> 
     <dcterms:created xsi:type="dcterms:W3CDTF">2013-03-22T12:13:00Z</dcterms:created> 
     <dcterms:modified xsi:type="dcterms:W3CDTF">2013-03-22T12:24:00Z</dcterms:modified> 
    </cp:coreProperties>', asText=TRUE) 

,我想提取這些行的信息:使用下面的代碼

<dcterms:created xsi:type="dcterms:W3CDTF">2013-03-22T12:13:00Z</dcterms:created> 
    <dcterms:modified xsi:type="dcterms:W3CDTF">2013-03-22T12:24:00Z</dcterms:modified> 

(我將使用最後一行爲例):

ns=c('dcterms'= 'http://purl.org/dc/elements/1.1/') 
date = xmlValue(getNodeSet(doc, '/*/dcterms:modified\ xsi:type=\"dcterms:W3CDTF\"', namespaces=ns)[[1]]) 

,但我得到這個錯誤:

XPath error : Invalid expression 
/*/dcterms:modified xsi:type="dcterms:W3CDTF" 
        ^
Error in xpathApply.XMLInternalDocument(doc, path, fun, ..., namespaces = namespaces, : 
    error evaluating xpath expression /*/dcterms:modified xsi:type="dcterms:W3CDTF" 
> 

有人可以幫助寫出正確的路徑嗎?

回答

0

看起來你沒有正確設置你的名字空間。您需要設置dctermsxsi,並且xpath名稱空間中的dcterms的URL需要與原始XML文檔中使用的URL相同。加上你的XPATH用於過濾屬性是有點關閉。嘗試

ns <- c('dcterms'= 'http://purl.org/dc/terms/', 
    'xsi'="http://www.w3.org/2001/XMLSchema-instance") 
xq <- '/*/dcterms:modified[@xsi:type=\"dcterms:W3CDTF\"]' 
date <- xmlValue(getNodeSet(doc, xq, namespaces=ns)[[1]]) 
+0

它的工作。謝謝! :)但爲什麼你必須改變名稱空間的設置?有什麼地方可以閱讀更多關於它的信息嗎?再次感謝 –

+0

好吧,你的XML文檔使用命名空間,所以你的xpath查詢也必須定義它們。這不是R特定的,但也許這個指南可能有助於給出一個概述:https://msdn.microsoft.com/en-us/library/ms950779.aspx – MrFlick