5

我正在从 Ruby 生成一个 CSV 文件,并且接收数据的系统无法接受底部的空行。

但是,在我添加了所有行(以 CRLF 结尾)之后,最后一行仍然有 CFLF,所以接收系统认为有一个空白的 lasy 行。

我通过执行此(hackish)代码来打开和截断文件来解决它:

  size = File.size(filename)
  File.truncate(filename, size-3)

如果它是最后一行,我是否缺少 ruby​​ CSV 中的某些功能以不添加 CRLF?

我编写 CSV 的代码是:

  csv = CSV.open(filename, "w", {:row_sep => "\r\n"})
  .. code to create an array of cols ..
  csv << cols

我尝试将其转换为使用字符串,而不是文件。但我没有成功。使用 << 运算符时,我不断收到错误消息。

更新:原来我有错误的问题......

已经有一段时间了,但我终于弄清楚发生了什么。我上传的主机系统也可以处理文件末尾的换行符 - Ruby CSV 输入了错误的换行符:\r\r\n instread of \r\n! 如果我写为文本文件,它会这样做。如果我写成二进制文件,问题就解决了。

如果其他人看到同样的问题,这是我的 Ruby:

csv = CSV.open(filename, "w", {:row_sep => "\r\n"}) # actually writes \r\r\n 

二进制模式修复它:

csv = CSV.open(filename, "wb", {:row_sep => "\r\n"}) # correctly writes \r\n
4

2 回答 2

3

如果您在写入之前将 CSV 作为字符串获取,则可以使用它String#chomp来删除尾随换行符。

如果您正在使用以下方式写入文件:

File.open('my.csv','w'){ |f| f.puts my_csv }

…然后您自己添加换行符,并且可以通过以下方式避免它:

File.open('my.csv','w'){ |f| f.write my_csv }

如果您提供用于生成和编写 CSV 的实际代码,我们可以进一步、更准确地为您提供帮助。

于 2012-04-21T14:29:31.927 回答
0

您可以只使用sub!删除文件末尾的任何换行符:

# my_csv_contents contains all of the CSV data
my_csv_contents.sub!(/(\r?\n)*\z/, "")
于 2012-04-21T14:07:20.563 回答