I have below mentioned dataframe:
ID Json_Data
PA-124 Json String
PA-145 Json String
PA-185 Json String
PA-149 Json String
I want to extract all the json field corresponding to each ID as mentioned below.
And I would like to know how to extract some specific field against each particular ID
(i.e Country).
ID Name Country Code
PA-124 Ajre Dubai 154
PA-145 Aret USA 485
PA-185 Cret Russia 445
PA-149 Oerp Canada 789
For that i have used below mentioned code, but it returns value against only one ID
out of ~1500 IDs.
My Code:
library(RJSONIO)
library(rjson)
library(jsonlite)
library(data.table)
f <- function(json, id){
tmp <- jsonlite::fromJSON(json)
tmp <- as.data.frame(tmp)
tmp$id <- id
return(tmp)
}
json_dfs <-
mapply(f, Df$Json_Data, Df$ID, SIMPLIFY = FALSE)
Dput:
structure(list(ID = c("PA-124", "PA-124", "PA-124"), Json_Data = c("{\n \"hed\": {\n \"srti\": \"RT1455\"\n },\n \"nnaesr\": {\n \"name\": \"\",\n \"firt\": \"alex\",\n \"last\": \"john\",\n \"birth\": \"26061981\",\n \"gender\": \"Male\"\n },\n \"iteret\": {\n \"adre\": \"asded14eer\",\n \"adfe\": \"\",\n \"sfdet\": \"\",\n \"sfeet\": \"\",\n \"serted\": \"\",\n \"sertgf\": \"\"\n },\n \"sefetgd\": {\n \"mobe\": \"2111111\",\n \"dfete\": \"\",\n \"tfet\": \"sdfet\"\n },\n \"aarfgeette\": {\n \"aarfgertte\": \"H NO. , dffr rtrg\",\n \"aarfgot2\": \"ids School, feeeete,\",\n \"aarfgot3\": \"\",\n \"aarfgot4\": \"\",\n \"aarfgot5\": \"\",\n \"sdfffy\": \"errtyy\",\n \"errrte\": \"efeteet\",\n \"sdetVb\": \"\",\n \"sdfes\": \"5500\",\n \"aarfgppr\": \"eretft er\",\n \"seferf\": \"ered\"\n }\n}",
"{\n \"hed\": {\n \"srti\": \"RT1455\"\n },\n \"nnaesr\": {\n \"name\": \"\",\n \"firt\": \"alex\",\n \"last\": \"john\",\n \"birth\": \"26061981\",\n \"gender\": \"Male\"\n },\n \"iteret\": {\n \"adre\": \"asded14eer\",\n \"adfe\": \"\",\n \"sfdet\": \"\",\n \"sfeet\": \"\",\n \"serted\": \"\",\n \"sertgf\": \"\"\n },\n \"sefetgd\": {\n \"mobe\": \"2111111\",\n \"dfete\": \"\",\n \"tfet\": \"sdfet\"\n },\n \"aarfgeette\": {\n \"aarfgertte\": \"efeet efet\",\n \"aarfgot2\": \"affe fe,\",\n \"aarfgot3\": \"\",\n \"aarfgot4\": \"\",\n \"aarfgot5\": \"\",\n \"sdfffy\": \"Telangana\",\n \"errrte\": \"Hyderabad\",\n \"sdetVb\": \"\",\n \"sdfes\": \"5500\",\n \"aarfgppr\": \"acefec ee\",\n \"seferf\": \"dfefe\"\n }\n}",
"{\n \"hed\": {\n \"srti\": \"RT1455\"\n },\n \"nnaesr\": {\n \"name\": \"\",\n \"firt\": \"alex\",\n \"last\": \"john\",\n \"birth\": \"26061981\",\n \"gender\": \"Male\"\n },\n \"iteret\": {\n \"adre\": \"asded14eer\",\n \"adfe\": \"\",\n \"sfdet\": \"\",\n \"sfeet\": \"\",\n \"serted\": \"\",\n \"sertgf\": \"\"\n },\n \"sefetgd\": {\n \"mobe\": \"2111111\",\n \"dfete\": \"\",\n \"tfet\": \"sdfet\"\n },\n \"aarfgeette\": {\n \"aarfgertte\": \"ad.de 25dfege\",\n \"aarfgot2\": \"adfed ,\",\n \"aarfgot3\": \"\",\n \"aarfgot4\": \"\",\n \"aarfgot5\": \"\",\n \"sdfffy\": \"adffe\",\n \"errrte\": \"Hyderabad\",\n \"sdetVb\": \"\",\n \"sdfes\": \"5500\",\n \"aarfgppr\": \"sadfe ad\",\n \"seferf\": \"dsfde\"\n }\n}"
)), row.names = c(NA, 3L), class = "data.frame")