3

我想从 yaml (PHPMyAdmin) 中的 Mysql 转储中获取数据,但数据没有被引号括起来。

我有可以从 0 开始的邮政编码,解析后我得到十进制版本的八进制值,而不是简单的字符串。

如何强制 Yaml 解析器不进行自动映射,或者只获取所有数据,因为它们是字符串?

谢谢

== 更新 ==

2185:
 id: 3274  
 civility: Mr  
 address: CROIX DES COMBES  
 zipcode: 04270
4

1 回答 1

5

如果您的邮政编码值是字符串,它们可能应该在数据库中,并且它们被正确转换为 YAML,那么它们将被 Ruby 的 YAML 解析器重新转换回字符串:

require 'yaml'
zip = '01234'

如果我们把它当作一个字符串,它就可以正确转换。

zip.to_yaml # => "--- \"01234\"\n"
YAML.load(zip.to_yaml) # => "01234"

如果我们将它视为一个整数,它的前导0会下降,这是我所期望的。

zip.to_i.to_yaml # => "--- 1234\n"
YAML.load(zip.to_i.to_yaml) # => 1234

在您的示例中:

zipcode: 04270

zipcode是一个 YAML 整数。它应该用引号括起来以保持其“字符串”。

Wikipedia 的 YAML 文章有一个很好的例子,展示了如何消除数据类型的歧义。


zipcode您可以在解析之前调整 YAML 中的所有实例,例如:

require 'yaml'

yaml_data = '2185:
 id: 3274  
 civility: Mr  
 address: CROIX DES COMBES  
 zipcode: 04270
'

yaml_data.gsub(/zipcode: (\d+)/, 'zipcode: "\1"') 
# => "2185:\n id: 3274  \n civility: Mr  \n address: CROIX DES COMBES  \n zipcode: \"04270\"\n"

YAML.load(yaml_data.gsub(/zipcode: (\d+)/, 'zipcode: "\1"')) 
# => {2185=>{"id"=>3274, "civility"=>"Mr", "address"=>"CROIX DES COMBES", "zipcode"=>"04270"}}
于 2012-05-31T09:22:05.720 回答