सबसे पहले , आप के बजाय (बूलियन्स वैक्टर के साथ) प्रत्यक्ष अनुक्रमण का उपयोग कर सकते फिर से पहुँचने के स्तंभ नाम यदि आप एक ही डेटा फ्रेम के साथ काम कर रहे हैं; यह इस्टा द्वारा इंगित के रूप में सुरक्षित होगा, और लिखने और निष्पादित करने के लिए तेज होगा। तो क्या आप केवल आवश्यकता होगी:
var.out.bool <- !names(data) %in% c("iden", "name", "x_serv", "m_serv")
और फिर, बस डेटा पुन: असाइन करें:
data <- data[,var.out.bool] # or...
data <- data[,var.out.bool, drop = FALSE] # You will need this option to avoid the conversion to an atomic vector if there is only one column left
दूसरा , लिखने के लिए तेज, आप सीधे उन कॉलमों को NULL असाइन कर सकते हैं जिन्हें आप हटाना चाहते हैं:
data[c("iden", "name", "x_serv", "m_serv")] <- list(NULL) # You need list() to respect the target structure.
अंत में , आप सबसेट () का उपयोग कर सकते हैं, लेकिन यह वास्तव में कोड में उपयोग नहीं किया जा सकता है (यहां तक कि सहायता फ़ाइल इसके बारे में चेतावनी देती है)। विशेष रूप से, मेरे लिए एक समस्या यह है कि यदि आप सीधे susbset () की ड्रॉप सुविधा का उपयोग करना चाहते हैं, तो आपको कॉलम नामों के अनुरूप अभिव्यक्ति के बिना उद्धरण लिखने की आवश्यकता है:
subset( data, select = -c("iden", "name", "x_serv", "m_serv") ) # WILL NOT WORK
subset( data, select = -c(iden, name, x_serv, m_serv) ) # WILL
एक बोनस के रूप में , यहाँ विभिन्न विकल्पों में से एक छोटा बेंचमार्क है, जो स्पष्ट रूप से दर्शाता है कि सबसेट सबसे धीमा है, और यह कि पहला, पुन: असाइन करने का तरीका सबसे तेज़ है:
re_assign(dtest, drop_vec) 46.719 52.5655 54.6460 59.0400 1347.331
null_assign(dtest, drop_vec) 74.593 83.0585 86.2025 94.0035 1476.150
subset(dtest, select = !names(dtest) %in% drop_vec) 106.280 115.4810 120.3435 131.4665 65133.780
subset(dtest, select = names(dtest)[!names(dtest) %in% drop_vec]) 108.611 119.4830 124.0865 135.4270 1599.577
subset(dtest, select = -c(x, y)) 102.026 111.2680 115.7035 126.2320 1484.174
कोड नीचे है:
dtest <- data.frame(x=1:5, y=2:6, z = 3:7)
drop_vec <- c("x", "y")
null_assign <- function(df, names) {
df[names] <- list(NULL)
df
}
re_assign <- function(df, drop) {
df <- df [, ! names(df) %in% drop, drop = FALSE]
df
}
res <- microbenchmark(
re_assign(dtest,drop_vec),
null_assign(dtest,drop_vec),
subset(dtest, select = ! names(dtest) %in% drop_vec),
subset(dtest, select = names(dtest)[! names(dtest) %in% drop_vec]),
subset(dtest, select = -c(x, y) ),
times=5000)
plt <- ggplot2::qplot(y=time, data=res[res$time < 1000000,], colour=expr)
plt <- plt + ggplot2::scale_y_log10() +
ggplot2::labs(colour = "expression") +
ggplot2::scale_color_discrete(labels = c("re_assign", "null_assign", "subset_bool", "subset_names", "subset_drop")) +
ggplot2::theme_bw(base_size=16)
print(plt)
subset(data, select=c(...))
var छोड़ने के लिए मेरे मामले में मदद करता है। सवाल हालांकि मुख्य रूपpaste("data$",var.out[i],sep="")
से लूप के अंदर ब्याज के कॉलम तक पहुंचने वाले हिस्से के बारे में था । मैं किसी कॉलम नाम को कैसे पेस्ट या किसी तरह से कर सकता हूं? आपके ध्यान और आपकी सहायता के लिए सभी का धन्यवाद