大佬教程收集整理的这篇文章主要介绍了ruby-on-rails – 在RoR中排序UTF-8字符串,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
在我的应用程序中,我有一个填充了国家/地区的选择框.当我的应用程序本地化时,每个现有的区域设置都有一个country.yml文件,将一个国家的ID与该国家的本地化名称相关联.我不能在yml文件中手动对字符串进行排序,因为我需要所有区域设置的ID一致.
我所做的是创建一个ascii_name方法,它使用unidecode
gem将重音和非拉丁字符转换为等价的ascii(例如,“Afeganistão”将成为“Afeganistao”),然后排序:
require 'unidecode' class Country def ascii_name Unidecoder.decode(Name).gsub("[?]","").gsub(/`/,"'").@R_696_10495@p end end Country.all.sorT_By(:&ascii_Name)
然而,这是有明显的问题:
>它不能正确地排序非拉丁语言区域,因为可能没有直接类似的拉丁字符.
>它不区分一封信和该字母的所有重音形式(因此,例如A和Ä可互换)
有谁知道一个更好的方法,我可以排序我的字符串?
这个宝石应该有帮助.它将sort_alphabetical和sort_alphabetical_by方法添加到Enumberable中.
以上是大佬教程为你收集整理的ruby-on-rails – 在RoR中排序UTF-8字符串全部内容,希望文章能够帮你解决ruby-on-rails – 在RoR中排序UTF-8字符串所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。