Chinaunix
标题:
关于 CSV.open 的用法
[打印本页]
作者:
zhn158
时间:
2010-12-17 14:40
标题:
关于 CSV.open 的用法
本帖最后由 zhn158 于 2010-12-17 15:07 编辑
最近在看《Beginning Ruby From Novice to Professional》, 249页 有一个使用CSV库处理文件的例子
文本文件 test.txt
Fred Bloggs,Manager,Male,45
Laura Smith,Cook,Female,23
Debbie Watts,Professor,Female,38
复制代码
Ruby 代码:
#!/usr/bin/ruby
require 'csv'
CSV.open('test.txt','r') do |person|
puts person.inspect
end
复制代码
按照书中的示例,代码应该打印三个数组,
["Fred Bloggs", "Manager", "Male", "45"]
["Laura Smith", "Cook", "Female", "23"]
["Debbie Watts", "Professor", "Female", "38"]
复制代码
但实际的运行结果如下:
输出:
<#CSV io_type:File io_path:"test.txt" encoding:GBK lineno:0 col_sep:"," row_sep:"\r\n" quote_char:"\"">
复制代码
请高手指点哪儿出了问题?
作者:
zhn158
时间:
2010-12-17 18:12
比较冷清呀,自己顶一下
作者:
Sapien
时间:
2010-12-17 19:21
解释器版本问题,你用的是 1.9 的,例子用的是 1.8 的。
$ ruby csv_example.rb
<#CSV io_type:File io_path:"test.txt" encoding:UTF-8 lineno:0 col_sep:"," row_sep:"\n" quote_char:"\"">
$ ruby1.8 csv_example.rb
["Fred Bloggs", "Manager", "Male", "45"]
["Laura Smith", "Cook", "Female", "23"]
["Debbie Watts", "Professor", "Female", "38"]
复制代码
作者:
zhn158
时间:
2010-12-17 22:29
多谢 Sapien
两个版本变化太大了
作者:
2gua
时间:
2010-12-17 22:37
Sapien,今天贡献很大啊,赞一个,今天白天俺不在呢,呵呵。
作者:
Sapien
时间:
2010-12-18 01:08
回复
4#
zhn158
别客气,我也刚学不久。解决问题是一种很好的学习方式,应该鼓励大家多提问题。
作者:
Sapien
时间:
2010-12-18 01:12
相比 1.8,1.9 添加了一些功能(比如对多字节字符的支持),还有很多细节的更改,使风格更统一了。所以我还是很期待 1.9 的普及的 ~~
作者:
2gua
时间:
2010-12-18 19:31
回复
7#
Sapien
1.9,应该说,目前普及的形式不错,已逐渐形成了主流Ruby版本。
作者:
netphp
时间:
2014-12-30 09:47
翻出老帖子了
我今天看这书,也是这问题,API变了,
CSV.open('text.txt', 'r') do |csv|
csv.each do |row|
puts row.inspect
end
end
作者:
rdcwayx
时间:
2015-01-15 17:59
netphp 发表于 2014-12-30 09:47
翻出老帖子了
我今天看这书,也是这问题,API变了,
直接用each就可以了
CSV.open('text.txt', 'r').each do |csv|
puts csv.inspect
end
复制代码
作者:
Sevk
时间:
2015-01-21 16:41
提示:
作者被禁止或删除 内容自动屏蔽
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2