你只需要帮助它记住环境terms
:
attr(lin.model$terms, ".Environment") <- .GlobalEnv
predict(lin.model, newdata)
## 1
## 4.17622
我会将其作为增强请求提交至http://github.com/jeroenooms/jsonlite/issues http://github.com/jeroenooms/jsonlite/issues
或者,您可以使用本机 R 二进制序列化:
saveRDS(lin.model, "lin.model.rds")
predict(readRDS("lin.model.rds"), newdata)
## 1
## 4.17622
除非你绝对需要文本序列化方法,在这种情况下你可以这样做:
saveRDS(lin.model, file="lin.model.txt", ascii=TRUE)
predict(readRDS("lin.model.txt"), newdata)
## 1
## 4.17622
The ascii=TRUE
制作对象的文本十六进制表示:
1f8b 0800 0000 0000 0003 ed5d c992 1cb9
91bd e797 cc1c 9806 381c db51 36a6 c35c
e61f 4a64 5153 3645 b255 2cb6 749a 6f1f
5fb0 bcc8 ca62 4b1a 33f5 25da 8c6d 8848
04fc f9f6 b004 10f5 870b 5d62 afa9 964b
4cb1 71b8 d456 2f91 2e99 8afc f421 5e5b
e510 73ef 9770 0d35 17aa 3d5f 6290 5fe3
850a c59c 2ef9 f2f5 e1cb e3f7 4bd4 27c6
bd18 2fff f69f 5f5f 1f5f 3e3e fef2 faef
f36e bdfc f5e1 e9f5 e9eb 9f2f 94d9 4554
1112 ae39 84dc 63d7 2287 de7a b2bb a975
... (lots more)
可以存储在二进制 blob 无法存储的位置。
如果您需要一个readable文本序列化方法,提交上述建议的增强请求可能是可行的方法。