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"
>
有人可以幫助寫出正確的路徑嗎?
它的工作。謝謝! :)但爲什麼你必須改變名稱空間的設置?有什麼地方可以閱讀更多關於它的信息嗎?再次感謝 –
好吧,你的XML文檔使用命名空間,所以你的xpath查詢也必須定義它們。這不是R特定的,但也許這個指南可能有助於給出一個概述:https://msdn.microsoft.com/en-us/library/ms950779.aspx – MrFlick