
R語言XML格式數(shù)據(jù)導入與處理
數(shù)據(jù)解析
XML是一種可擴展標記語言,它被設(shè)計用來傳輸和存儲數(shù)據(jù)。XML是各種應用程序之間進行數(shù)據(jù)傳輸?shù)淖畛S玫墓ぞ?。它與Access,Oracle和SQL Server等數(shù)據(jù)庫不同,數(shù)據(jù)庫提供了更強有力的數(shù)據(jù)存儲和分析能力,例如:數(shù)據(jù)索引、排序、查找、相關(guān)一致性等,它僅僅是存儲數(shù)據(jù)。事實上它與其他數(shù)據(jù)表現(xiàn)形式最大的不同是:它極其簡單,這是一個看上去有點瑣細的優(yōu)點,但正是這點使它與眾不同。
針對XML格式數(shù)據(jù),R語言XML包可以對其進行數(shù)據(jù)導入與處理,詳見下面的案例說明。
案例1
直接輸入一段標記語言文本,使用XML包解析。
library(XML)
tt =
'<x>
<a>text</a>
<b foo="1"/>
<c bar="me">
<d>a phrase</d>
</c>
</x>'
doc = xmlParse(tt)
xmlToList(doc)
# use an R-level node representation
doc = xmlTreeParse(tt)
xmlToList(doc)
案例2
導入已有的xml格式數(shù)據(jù)并處理,本案例用到的是手機通訊錄xml數(shù)據(jù),按如下步驟操作:
#讀取xml格式數(shù)據(jù)并解析
xmlfile=xmlParse(file.choose(),encoding="UTF-8")
class(xmlfile)
#形成根目錄列表數(shù)據(jù)
xmltop = xmlRoot(xmlfile)
class(xmltop) #查看類
xmlName(xmltop) #查看根目錄名
xmlSize(xmltop) #查看根目錄總數(shù)
xmlName(xmltop[[1]]) #查看子目錄名
# 查看第一個子目錄
xmltop[[1]]
# 查看第二個子目錄
xmltop[[2]]
#子目錄節(jié)點
xmlSize(xmltop[[1]]) #子目錄節(jié)點數(shù)
xmlSApply(xmltop[[1]], xmlName) #子目錄節(jié)點名
xmlSApply(xmltop[[1]], xmlAttrs) #子目錄節(jié)點屬性
xmlSApply(xmltop[[1]], xmlSize) #子目錄節(jié)點大小
#查看第一個子目錄的第一個節(jié)點
xmltop[[1]][[1]]
#查看第一個子目錄的第二個節(jié)點
xmltop[[1]][[2]]
#第二個子目錄
xmltop[[2]][[1]]
xmltop[[2]][[2]]
xmltop[[1]][[3]][[1]][[1]] #查看聯(lián)系人電話
xmltop[['Contact']][['PhoneList']][[1]][[1]] #第二種方式
getNodeSet(xmltop, "http://Contact/PhoneList")[[1]][[1]][[1]] #第三種方式
xmltop[[1]][[3]][[1]][[1]] = 13717232323 #更改聯(lián)系人電話
xmltop[[1]][[1]][[1]]= "zhangsan "#更改聯(lián)系人姓名
#保存
saveXML(xmltop, file="out.xml",encoding="UTF-8")
xml格式轉(zhuǎn)dataframe
按如下步驟操作:
xmlToDataFrame(xmlfile) #第一種方式,直接用xmlToDataFrame()函數(shù)
library("plyr") #第二種方式,數(shù)據(jù)格式處理專用包plyr
MyContact=ldply(xmlToList(file.choose()), data.frame) #先轉(zhuǎn)成list,再轉(zhuǎn)dataframe
View(MyContact)
# 查看聯(lián)系方式
MyContact[,c("Name" ,"PhoneList.Phone.text")]
# 聯(lián)系方式保存
write.csv(MyContact, "MyContact.csv", row.names=FALSE)
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉(zhuǎn)換:從基礎(chǔ)用法到實戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉(zhuǎn)換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認知誤區(qū) 在 MySQL 數(shù)據(jù)庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結(jié)構(gòu)數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結(jié)構(gòu)數(shù)據(jù)(如數(shù)據(jù)庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預期算子的內(nèi)涵、作用與應用解析 動態(tài)隨機一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結(jié)構(gòu)數(shù)據(jù)特征價值的專業(yè)核心 表結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲的結(jié)構(gòu)化數(shù)據(jù),如數(shù)據(jù)庫表、Excel 表、 ...
2025-09-17Excel 導入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實戰(zhàn)應用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據(jù)時,“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗與 t 檢驗:差異、適用場景與實踐應用 在數(shù)據(jù)分析與統(tǒng)計學領(lǐng)域,假設(shè)檢驗是驗證研究假設(shè)、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結(jié)構(gòu)數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 存儲的結(jié)構(gòu)化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計劃中 rows 數(shù)量的準確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調(diào)優(yōu)中,EXPLAIN執(zhí)行計劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實踐指南 在 Python 進行 HTTP 網(wǎng)絡請求開發(fā)時(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價值的核心操盤手 表格結(jié)構(gòu)數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫表)是企業(yè)最基礎(chǔ)、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調(diào)用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點數(shù)據(jù)的科學計數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長浮點數(shù)據(jù)時的科學計數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務數(shù)據(jù)分析步驟的落地者與價值優(yōu)化者 業(yè)務數(shù)據(jù)分析是企業(yè)解決日常運營問題、提升執(zhí)行效率的核心手段,其價值 ...
2025-09-12用 SQL 驗證業(yè)務邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實戰(zhàn)指南 在業(yè)務系統(tǒng)落地過程中,“業(yè)務邏輯” 是連接 “需求設(shè)計” 與 “用戶體驗 ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據(jù)驅(qū)動下的精準零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當下,精準營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務數(shù)據(jù)分析:概念辨析與協(xié)同價值 在數(shù)據(jù)驅(qū)動決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實踐到業(yè)務價值挖掘 在數(shù)據(jù)分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價值導向 統(tǒng)計模型作為數(shù)據(jù)分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10