草庐IT

php删除无效字符

全部标签

Ruby one liner 将数组元素传递到带有分隔符的字符串中

我有一个这样的数组:myarray=['value1','value2','value3']我正在寻找这样的单元素数组:mynewarray=['value1|value2|value3']我知道如何使用each并连接成一个字符串来做到这一点,但我想知道是否有一种单行代码和漂亮的Ruby方式来做到这一点...... 最佳答案 您可以使用Array#join方法。myarray.join('|')Array#joindoc:返回通过将数组的每个元素转换为一个字符串,由sep分隔。["a","b","c"].join#=>"abc"["

ruby - 检查字符串是否仅包含 ruby​​ 中的数字

我有一个字符串作为参数传递给一个函数。在这里,我想检查字符串是否只包含数字。所以我进行了如下检查:defcheck_string(string)result=falseifstring.to_i.to_s.eql?stringresult=trueendresultend但当字符串以0开头时就会出现问题。在这种情况下,将返回false。check_string('123')#=>truecheck_string('0123')#=>false我该如何解决这个问题? 最佳答案 你可以试试下面的方法defcheck_string(str

ruby - 如何从 JSON 字符串中删除反斜杠?

我有一个如下所示的JSON字符串'{\"test\":{\"test1\":{\"test1\":[{\"test2\":\"1\",\"test3\":\"foo\",\"test4\":\"bar\",\"test5\":\"test7\"}]}}}'我需要使用Ruby或Rails将其更改为以下内容:'{"test":{"test1":{"test1":[{"test2":"1","test3":"foo","test4":"bar","test5":"bar2"}]}}}'我需要知道如何删除那些斜杠。 最佳答案 要避免在控制台

Ruby:如何使用 sprintf() 在数字字符串前面添加零

我想将邮政编码标准化为5位数字,用零替换任何缺失的字符,如下所示:"95616">>"95616""854">>"00854""062">>"00062""0016">>"00016"我试过像这样使用sprintfsprintf("%05s",zipcode)和这样sprintf("%0.5d",zipcode).两者都给出错误的答案。使用s:"95616">>"95616""854">>"854""062">>"062""0016">>"0016"这是正确的字符数,但使用空格而不是零。使用d:"95616">>"95616""854">>"00854""062">>"00050""0

ruby - 删除散列中不在数组中的键

我找不到从散列中删除不在给定键名称数组中的键的方法。我读到我可以使用except或slice,但我如何才能向他们提供我想保留的键名列表?例如,如果我有这个散列:entry={:title=>"casablanca",:media=>"dvd",:localeLanguage=>"en",:imdb=>"",:freebase=>"",:originalTitle=>'casablanca',:season=>'1',:episode=>'3'}我只想保留,比如说,:title、:media和:localeLanguage,我怎么能只保留那些值我指定的键名?

ruby-on-rails - 使用带有无效字符的 Net::FTP gettextfile(ASCII-8BIT 与 UTF-8)

我有一个通过FTP从大型机获取平面文件的进程。这通常工作正常,但有时文件会包含一些重音字符。如果我尝试获取包含口音的文件,整个过程会失败并出现以下错误:Encoding::UndefinedConversionError:"\x88"fromASCII-8BITtoUTF-8那是使用Net::FTP的gettextfile方法。许多人建议简单地切换到getbinaryfile-这样做将允许我下载文件,但生成的文件是我无法再解析的东西(说它是UTF-8,但内容使没有意义)。有没有什么方法可以简单地获取文件并将其保存为ASCII,而无需让Rails自动将输出转换为UTF-8?这是我的代码:

ruby - 比较相等的字符串在 Hash 中找不到相同的对象

我有两个看起来相等的字符串:context="MarriottInternationalWorld’sMostADMIREDLodgingCompanybyFORTUNEfor14thyr.via@FortuneMagazinehttp://cnnmon.ie/1kcFZSQ"slice_str=context.slice(105,24)#=>"http://cnnmon.ie/1kcFZSQ"str="http://cnnmon.ie/1kcFZSQ"slice_str==str#=>trueslice_str.eql?str#=>true但是当我在以字符串为键的散列中查找值时,它们

ruby - ruby 是否有一个列表类型可以在添加/删除时保持内容排序?

我需要一个Ruby中的数据结构,在添加或删除元素时保持其元素排序,并允许(至少)能够从列表中弹出第一个元素。我在ruby​​文档中找到的最接近的是SortedSet.但是,这似乎没有提供任何方式来通过索引访问元素(甚至弹出第一个元素)这些是我需要的具体操作:将对象添加到列表从列表中弹出第一个对象检查一个对象是否在列表中从列表中删除对象(按对象,而不是按索引)ruby是否为此内置了任何东西,或者是否有任何我可以获取的库可以提供给我?我可以毫不费力地实现一个,但如果可能的话,我宁愿使用一个已经存在的。目前我使用的是Ruby1.8,但切换到1.9可能没问题。编辑:由于似乎有些困惑,我需要的排

ruby-on-rails - to_json 不将特殊字符转换为 unicode 样式

我在将哈希值转换为json字符串时遇到特殊字符问题。Ruby2.0/Rails3.2.21一切正常,也就是说,puts"“".to_json#"\u201c"但是使用Ruby2.3.0/Rails4.2.5.1我明白了puts"“".to_json#"“"有什么方法可以强制Ruby2.3.0将特殊字符转换为unicode样式字符串(\uXXXX)?备注:注意在Ruby2.3/Rails4中,我们得到"“".to_json.bytesize==5#true但是,在2.0中我们得到"“".to_json.bytesize==8#true很明显,不同的是字符串本身,而不是不同的输出格式。

ruby-on-rails - Ruby 2.2:PG::CharacterNotInRepertoire:错误:编码 "UTF8"的无效字节序列

我正在升级Rails4.1应用程序以使用Ruby2.2。在升级期间,事实证明该应用程序使用了旧版本的pggem(0.12),并且gem没有使用Ruby2.2安装。所以我尝试使用更新版本的pggem(0.17.1)。现在在系统中创建新用户时有时会出现以下错误:PG::CharacterNotInRepertoire:ERROR:invalidbytesequenceforencoding"UTF8"Ruby2.2和Postgres是否存在任何已知问题?看起来应用程序配置为使用unicode:config.encoding="utf-8"在application.rb中设置,encodin