45

我希望能够在 R 中创建一系列字母(以帮助从 SPSS 文件中导入数据)

创建一个数字序列非常容易,例如:

seq(1,1000)
[1] 1 2 3 4 5 6 ... 1000

paste("something_",1:12,sep="")
[1] something1 something2 ... something12

但是有没有像这样附加、粘贴或创建字母序列的功能?

paste("This_",a:z,sep="")
[1]This_a This_b This_c ... This_4z

提前致谢!

4

4 回答 4

60

这就是你要找的:

> paste("This_", letters, sep="")

> [1] "This_a" "This_b" "This_c" "This_d" "This_e" "This_f" "This_g" "This_h"
  [9] "This_i" "This_j" "This_k" "This_l" "This_m" "This_n" "This_o" "This_p"
  [17] "This_q" "This_r" "This_s" "This_t" "This_u" "This_v" "This_w" "This_x"
  [25] "This_y" "This_z"
于 2009-09-17T16:15:38.003 回答
21

你看了吗

?LETTERS

这不是你想要的吗?其他还有paste()和相关的功能。

编辑:也许collapse=粘贴是你需要的:

R> replicate(5, paste(sample(LETTERS, 10, replace=TRUE), collapse=""))
[1] "OHZBIYEFMD" "UINBOFEIXN" "UORJZATYNT" "ZNPWNBFFXJ" "ZOKYMTCDKZ"
R> 
于 2009-09-17T15:20:06.990 回答
13

对于“a”到“z”,它是

letters

对于“A”到“Z”其

LETTERS

并打印序列中的特定字母,比如如果你只想要 j、k & l

letters[10:12]
于 2016-08-29T11:22:59.317 回答
2

猜你想得到A-1、A-2、A-3、B-1、B-2、B-3、C-1、C-2、C-3等等……

我试过这个

replicate(3, paste0(LETTERS[1:10], sep="-", 1:3, collapse=", ")

但这样我得到

A-1、B-2、C-3、D-1、E-2、F-3、G-1、H-2、I-3、J-1" "A-1、B-2、C -3、D-1、E-2、F-3、G-1、H-2、I-3、J-1、A-1、B-2、C-3、D-1、E-2 , F-3, G-1, H-2, I-3, J-1"

我也试过

paste0(replicate(3, LETTERS[1:10]), sep = "-", 1:3)

但得到了相同的结果..

如何获得所需的序列

于 2020-03-21T15:52:49.787 回答