gpt4 book ai didi

r - 有没有办法使用 R 将文件写入使用 SSL 的 FTP 服务器?

转载 作者:太空宇宙 更新时间:2023-11-03 13:05:33 25 4
gpt4 key购买 nike

我有一个 R 脚本,它使用 RCurl 以 .csv 格式从 QuickBase 中提取数据。目前,在使用 write.table 函数时,我只是将其定向到本地文件夹。我想直接写入我认为正在使用 SSL 的 FTP 站点。我有用户名和密码,在选择连接类型“FTP - SSL(Explict AUTH Over TLS)”后,可以使用 cyberduck 等客户端进行连接。

我试过只使用 ftpUpload 函数,但它拒绝让我建立连接。

如果您能提供有关下一步该去哪里的任何帮助或建议,我们将不胜感激。

最佳答案

高级

我知道(在 R 中)完成这项工作的最佳方法是包装对系统函数的调用。我个人使用lftp ,它可以很好地处理:

  • FTPS
  • 多个文件输入/输出
  • 正则表达式和通配 rune 件命名

这确实有硬件特定的缺点;它并没有很好地包含在 R 中。也就是说,它可以通过利用擅长其工作的工具为您节省大量时间。


示例包装器

LFTP 的包装器可能类似于下面的函数——这是我在生产中使用的变体;我删除了依赖于更广泛包的日志记录功能。从根本上说,这就是为我移动文件的原因。

#' lftp wrapper to get/put file(s) from ftp-like sites
#'
#' @param process list, pipeable etl objects
#' @param configuration vector (text), list of
#' arguments to supply after call to lftp
#' @param skip boolean, whether to skip this step (testing)
#'
#' @details wrapper around lftp command line tool
#'
#' @export
#'
ftp <- function(configuration, skip = FALSE) {
if (!skip) {
system2("lftp",
args = configuration)
}
}

配置

包装器的最大部分是配置 向量。配置向量允许您将任意一组参数传递给 lftp,包括完成工作所需的参数。

示例配置向量可能如下所示:

c(
'your.ftp-server.com',
paste("-e", '"put '/path/to/file.csv' -o '/destination/'; exit;"'
)

注意您需要小心引用(或者您可以合并 shQuote() ,但那是一个不同的项目)。

放在一起

要回答您的具体问题,您可以在 R 中使用它来:

  • 使用 rCurl
  • 从 Quick Base 获取您正在使用的数据
  • 将其写入硬件某处的文件
  • 使用 ftp() 来利用 lftp 将文件发送到目的地

关于r - 有没有办法使用 R 将文件写入使用 SSL 的 FTP 服务器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48913880/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com