出于某种原因,当我用科学记数法转换数字的字符列时,小数不会被保留。
> str(output)
'data.frame': 213950 obs. of 2 variables:
$ ColA : chr ".3370E+03" ".3375E+03" ".3380E+03" ".3385E+03" ...
$ ColB : chr ".4942E+00" ".5295E+00" ".5682E+00" ".6091E+00" ...
> output$ColA = as.numeric(output$ColA)
> str(output)
'data.frame': 213950 obs. of 2 variables:
$ ColA : num 337 338 338 338 339 ...
$ ColB : chr ".4942E+00" ".5295E+00" ".5682E+00" ".6091E+00" ...
我希望它能读到:
$ ColA : num 337 337.5 338 338.5 ...
我尝试了this SO question的解决方案,但没有运气:
> options(digits=9)
> str(output)
'data.frame': 213950 obs. of 2 variables:
$ ColA : num 337 338 338 338 339 ...
$ ColB : chr ".4942E+00" ".5295E+00" ".5682E+00" ".6091E+00" ...
发生了什么事?
答案 0 :(得分:3)
您可以使用以下选项关闭数字的科学记数法;
options(scipen = 999)
这会使所有数字显示为小数。