从给定的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全局设置?
答案 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