เชื่อมต่อเวกเตอร์ของสตริง / ตัวอักษร


273

หากฉันมีเวกเตอร์ประเภทอักขระฉันจะเชื่อมค่าเป็นสตริงได้อย่างไร นี่คือวิธีที่ฉันจะทำกับวาง () :

sdata = c('a', 'b', 'c')
paste(sdata[1], sdata[2], sdata[3], sep ='')

"abc"ยอมให้

แต่แน่นอนว่าใช้งานได้ถ้าฉันรู้ระยะเวลาของsdataล่วงหน้า

คำตอบ:


480

ลองใช้อาร์กิวเมนต์การยุบที่ว่างเปล่าภายในฟังก์ชันวาง:

paste(sdata, collapse = '')

ขอบคุณhttp://twitter.com/onelinetips/status/7491806343


7
เพียงแค่ทราบว่าหากsdataสามารถมีสตริงอย่างใดอย่างหนึ่งซึ่งมีความยาวเท่ากันหรือมีความยาวผันแปรได้paste(sdata, sep = '', collapse = '')ควรใช้เพื่อหลีกเลี่ยงผลลัพธ์ที่ไม่คาดคิด
zelanix

42

คำตอบของ Matt เป็นคำตอบที่ถูกต้องอย่างแน่นอน อย่างไรก็ตามนี่เป็นวิธีการแก้ปัญหาทางเลือกเพื่อการบรรเทาการ์ตูน:

do.call(paste, c(as.list(sdata), sep = ""))

6
คุณสามารถใช้คำสั่ง Apply () ในนั้นได้จริงๆ ถ้าคุณทำฉันจะโหวตให้คุณ;)
JD Long

นี่จะเป็นทางออกที่ดีที่สุดหากไม่มีcollapseพารามิเตอร์ บรรเทาตลกจึงไม่มากถ้าคุณเพิ่งจริงต้องทำบางสิ่งบางอย่างที่คล้ายกันมาก :)
บินแกะ

9

คุณสามารถใช้stri_pasteฟังก์ชั่นที่มีcollapseพารามิเตอร์จากstringiแพ็คเกจเช่นนี้:

stri_paste(letters, collapse='')
## [1] "abcdefghijklmnopqrstuvwxyz" 

และมาตรฐานบางอย่าง:

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

2
ฉันไม่เคยทำการวัดประสิทธิภาพของอาร์นีซเพื่อเรียนรู้สิ่งใหม่
Torrien

6

สำหรับsdata:

gsub(", ","",toString(sdata))

สำหรับเวกเตอร์จำนวนเต็ม:

gsub(", ","",toString(c(1:10)))

6
นี่เป็นคำตอบที่อันตราย - ถ้ามีลำดับจุลภาคในองค์ประกอบของเวกเตอร์คำตอบนี้จะลบออก
C8H10N4O2

5

คำตอบของ Matt Turner เป็นคำตอบที่ถูกต้องอย่างแน่นอน อย่างไรก็ตามด้วยจิตวิญญาณของคำตอบของเคนวิลเลียมส์คุณสามารถทำได้:

capture.output(cat(sdata, sep="")) 

1

นี่คือฟังก์ชั่นยูทิลิตี้เล็ก ๆ น้อย ๆ ที่ยุบรายการของค่าที่มีชื่อหรือไม่มีชื่อกับสตริงเดี่ยวเพื่อให้การพิมพ์ง่ายขึ้น มันจะพิมพ์บรรทัดของโค้ดเอง มาจากตัวอย่างรายการของฉันในหน้าR

สร้างรายการบางรายการที่มีชื่อหรือไม่มีชื่อ:

# 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'

นี่คือฟังก์ชั่นที่จะแปลงรายชื่อหรือรายการที่ไม่มีชื่อเป็นสตริง:

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)
  }
}

ทดสอบฟังก์ชันด้วยรายการที่สร้างขึ้นก่อนหน้า:

> 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"

ทดสอบฟังก์ชันด้วยชุดย่อยขององค์ประกอบรายการ:

> 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"
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.