例如,我有字符串"The Dark Knight 10.0“,我需要将它转换为表单的键值散列:
黑暗骑士=> 10.0
如何创建一个块来将从.db文件中获取的此表单的所有字符串转换为上述表单的键值散列?
谢谢你的帮助!
发布于 2014-09-28 21:36:41
您需要一个正则表达式来隔离电影名称和分级(如果10.0是级别)。为了提供一个更精确的正则表达式,我需要更多的输入,但是对于上面的一个表达式,这就完成了工作(如果电影,例如,Transformer29.0,它将正确地使用Transformers 2 => 9.0,它也会注意到):
def convert_string_into_key_value_and_add_to_hash(string, hash_to_add_to)
name = string[/^[\w .]+(?=\s+\d+\.\d+$)/]
number = string[/\d+\.\d+$/].to_f
hash_to_add_to[name] = number
end
str = "The Dark Knight 10.0"
hash = {}
convert_string_into_key_value_and_add_to_hash(str, hash)
p hash #=> {"The Dark Knight"=>10.0}更多的'Rubyist‘方式是使用r分区:
def convert_string_into_key_value_and_add_to_hash(string, hash_to_add_to)
p partition = string.rpartition(' ')
hash_to_add_to[partition.first] = partition.last.to_f
end
str = "The Dark Knight 2 10.0"
hash = {}
convert_string_into_key_value_and_add_to_hash(str, hash)
p hash #=> {"The Dark Knight 2"=>10.0}https://stackoverflow.com/questions/26089862
复制相似问题