Dividir a coluna da sequência do quadro de dados em várias colunas

Eu gostaria de pegar os dados do formulário

before = data.frame(attr = c(1,30,4,6), type=c('foo_and_bar','foo_and_bar_2'))
  attr          type
1    1   foo_and_bar
2   30 foo_and_bar_2
3    4   foo_and_bar
4    6 foo_and_bar_2

E usesplit() na coluna "type"de cima para obter algo assim:

  attr type_1 type_2
1    1    foo    bar
2   30    foo  bar_2
3    4    foo    bar
4    6    foo  bar_2

Eu vim com algo incrivelmente complexo envolvendo alguma forma deapply funcionou, mas desde então eu perdi isso. Parecia muito complicado para ser o melhor caminho. Eu posso usarstrsplit como abaixo, mas não está claro como recuperá-lo em duas colunas no quadro de dados.

> strsplit(as.character(before$type),'_and_')
[[1]]
[1] "foo" "bar"

[[2]]
[1] "foo"   "bar_2"

[[3]]
[1] "foo" "bar"

[[4]]
[1] "foo"   "bar_2"

Obrigado por qualquer indicação. Ainda não entendi muito bem as listas R.

questionAnswers(15)

yourAnswerToTheQuestion