将字符串转换为定义小数位数的数字

时间:2015-10-06 15:45:23

标签: r string numeric

从给定的georeferred点数据框中,我发现字符列中的坐标格式如下

"44.524768336 11.4832955249"
"44.6858512233 11.1698766486"
"44.498179364 11.6599683838"

要从每行中提取数值,我使用了以下命令(我将以第一行为例)。

res <- strsplit(x = "44.524768336 11.4832955249", split = " ", fixed = T)
res
[[1]]
[1] "44.524768336"  "11.4832955249"

as.numeric(res[[1]][1])
[1] 44.52477
as.numeric(res[[1]][2])
[1] 11.4833

在这次转换中,我丢失了6位小数。 有没有一种方法可以将字符串转换为数字,设置小数位数而不修改任何R全局设置?

2 个答案:

答案 0 :(得分:7)

你实际上没有丢失数字;这就是如何打印到控制台:

options(digits = 4)
R> as.numeric(res[[1]][1])
#[1] 44.52
## 
options(digits = 12)
R> as.numeric(res[[1]][1])
#[1] 44.524768336

正如David Arenburg的评论中所指出,您也可以使用print(..., digits = <n>)

答案 1 :(得分:0)

我们找到了以下解决方案:

string.number <- "44.004768336"

# Splitting the string in integer and decimal part
number.part <- strsplit(string.number, ".", fixed = T)
as.numeric(number.part[[1]][1])   # Integer part
[1] 44
as.numeric(number.part[[1]][2])   # Decimal part. Note the effect of the leading zeros
[1] 4768336

# saving the current and set the new setting the "digits" option
getOption(x = "digits")
[1] 11
current.n.dgt <- getOption("digits")
options(digits = 11)

# Combining integer and decimal in a number saving the required numbers of decimal digits
integer.part <- as.numeric(number.part[[1]][1])
exp.numb <- (trunc(log10(as.numeric(number.part[[1]][2])))+1+(nchar(number.part[[1]][2])-nchar(as.character(as.numeric(number.part[[1]][2])))))
decimal.part <- as.numeric(number.part[[1]][2])/(10^exp.numb)
res.number <- integer.part + decimal.part
res.number
[1] 44.004768336

避免字符串拆分的更简单方法是以下

getOption("digits")
[1] 7
current.n.dgt <- getOption("digits")

string.number <- "44.004768336"
options(digits = 11)
as.numeric(string.number)
[1] 44.004768336

options(digits = current.n.dgt)
getOption("digits")
[1] 7