Odpowiedzi:
Spróbuj użyć pustego argumentu zwinięcia w funkcji wklejania:
paste(sdata, collapse = '')
Odpowiedź Matta jest zdecydowanie poprawna. Oto jednak alternatywne rozwiązanie dla celów komiksowych:
do.call(paste, c(as.list(sdata), sep = ""))
collapse
parametr nie istniał. więc niewiele komediowej ulgi, jeśli ostatnio musiałeś zrobić coś bardzo podobnego :)
Możesz użyć stri_paste
funkcji z collapse
parametrem z stringi
pakietu w następujący sposób:
stri_paste(letters, collapse='')
## [1] "abcdefghijklmnopqrstuvwxyz"
I niektóre punkty odniesienia:
require(microbenchmark)
test <- stri_rand_lipsum(100)
microbenchmark(stri_paste(test, collapse=''), paste(test,collapse=''), do.call(paste, c(as.list(test), sep="")))
Unit: microseconds
expr min lq mean median uq max neval
stri_paste(test, collapse = "") 137.477 139.6040 155.8157 148.5810 163.5375 226.171 100
paste(test, collapse = "") 404.139 406.4100 446.0270 432.3250 442.9825 723.793 100
do.call(paste, c(as.list(test), sep = "")) 216.937 226.0265 251.6779 237.3945 264.8935 405.989 100
Oto mała funkcja narzędziowa, która zwija nazwaną lub nienazwaną listę wartości do jednego łańcucha, aby ułatwić drukowanie. Wydrukuje również samą linię kodu. Pochodzi z mojej listy przykładów na stronie R.
Wygeneruj niektóre listy o nazwach lub nazwach:
# Define Lists
ls_num <- list(1,2,3)
ls_str <- list('1','2','3')
ls_num_str <- list(1,2,'3')
# Named Lists
ar_st_names <- c('e1','e2','e3')
ls_num_str_named <- ls_num_str
names(ls_num_str_named) <- ar_st_names
# Add Element to Named List
ls_num_str_named$e4 <- 'this is added'
Oto funkcja, która konwertuje nazwaną lub nienazwaną listę na ciąg znaków:
ffi_lst2str <- function(ls_list, st_desc, bl_print=TRUE) {
# string desc
if(missing(st_desc)){
st_desc <- deparse(substitute(ls_list))
}
# create string
st_string_from_list = paste0(paste0(st_desc, ':'),
paste(names(ls_list), ls_list, sep="=", collapse=";" ))
if (bl_print){
print(st_string_from_list)
}
}
Testowanie funkcji z wcześniej utworzonymi listami:
> ffi_lst2str(ls_num)
[1] "ls_num:=1;=2;=3"
> ffi_lst2str(ls_str)
[1] "ls_str:=1;=2;=3"
> ffi_lst2str(ls_num_str)
[1] "ls_num_str:=1;=2;=3"
> ffi_lst2str(ls_num_str_named)
[1] "ls_num_str_named:e1=1;e2=2;e3=3;e4=this is added"
Testowanie funkcji za pomocą podzbioru elementów listy:
> ffi_lst2str(ls_num_str_named[c('e2','e3','e4')])
[1] "ls_num_str_named[c(\"e2\", \"e3\", \"e4\")]:e2=2;e3=3;e4=this is added"
> ffi_lst2str(ls_num[2:3])
[1] "ls_num[2:3]:=2;=3"
> ffi_lst2str(ls_str[2:3])
[1] "ls_str[2:3]:=2;=3"
> ffi_lst2str(ls_num_str[2:4])
[1] "ls_num_str[2:4]:=2;=3;=NULL"
> ffi_lst2str(ls_num_str_named[c('e2','e3','e4')])
[1] "ls_num_str_named[c(\"e2\", \"e3\", \"e4\")]:e2=2;e3=3;e4=this is added"
sdata
może zawierać ciągi o tej samej długości lub o zmiennej długości,paste(sdata, sep = '', collapse = '')
należy użyć, aby uniknąć nieoczekiwanych wyników.