草庐IT

PHP奇怪的按位运算符对字符串的影响

全部标签

ruby-on-rails - Ruby 在文件中查找字符串并打印结果

我已经有很长时间没有使用ruby​​来做这样的事情了,但是,我忘记了如何打开文件、查找字符串以及打印ruby​​找到的内容。这是我所拥有的:#!/usr/bin/envrubyf=File.new("file.txt")text=f.readiftext=~/string/thenputstestend我想确定config/routes.rb中的“文档根目录”(路由)如果我打印字符串,它会打印文件。我不记得这是什么了,但我需要知道。希望我能让它打印出这个:#Routeis:blahblahblahblah 最佳答案 File.ope

ruby - Ruby 字符串字典中的快速模糊/近似搜索

我有一个包含50K到100K字符串的字典(最多可以包含50个以上的字符),我正在尝试查找给定字符串是否在具有“编辑”距离公差的字典中。(例如Levenshtein)。在进行搜索之前,我可以预先计算任何类型的数据结构。我的目标是尽快针对该字典运行数千个字符串并返回最近的邻居。如果有一个明显更快的算法,我会得到一个bool值来说明给定的是否在字典中为此,我首先尝试计算所有Levenshtein距离并取最小值,这显然非常慢。所以我尝试根据这篇文章实现一个LevenshteinTriehttp://stevehanov.ca/blog/index.php?id=114在这里查看我的重现基准的要

ruby - 为什么 Ruby 使用自己的安全导航运算符语法?

Ruby2.3.0引入了安全导航语法,它通过引入一个新的运算符来简化链式方法调用的nil处理,该运算符仅在先前语句的值不是nil。这是一个已经存在于C#、Groovy和Swift中的特性。例如inGroovy,语法是foo?.bar这基本上意味着结果值是foo.bar除非foo是null,在这种情况下返回值也是null因此不会抛出异常。还有C#(称为空条件运算符)和Swift(称为可选链接表达式)使用此表示法。所以语法在其他语言中似乎是相当标准的。现在,为什么在Ruby中语法是foo&.bar代替? 最佳答案 此答案基于thedis

ruby - 相同的字符串但不同的字节码

我有两个字符串:a='hànội'b='hànội'当我将它们与a==b进行比较时,它返回false。我检查了字节码:a.bytes=[104,97,204,128,32,110,195,180,204,163,105]b.bytes=[104,195,160,32,110,225,187,153,105]这是什么原因?我该如何修复它以便a==b返回true? 最佳答案 这是Unicodeequivalence的问题.为了比较这些字符串,您需要对它们进行规范化,以便它们都对这些类型的字符使用相同的字节序列。a.unicode_n

ruby - 将字符串对象转换为事件记录类

所以我很感兴趣是否有一种方法可以将字符串转换为事件记录类。示例:我有一个继承自ActiveRecord::Base的User类。有什么方法可以将字符串"User"转换为User类,这样我就可以使用ActiveRecord方法,例如find、哪里等 最佳答案 String#constantize返回具有字符串名称的常量的值。对于"User",这是您的User类:"User".constantize#=>User(id:integer,...)您可以将其分配给一个变量并调用ActiveRecord方法:model="User".cons

ruby - 带有临时文件的奇怪的 Ruby IO

这让我发疯。请考虑以下事项:require'open-uri'#setuptempfileextname=File.extnamefile_urlbasename=File.basename(file_url,extname)file=Tempfile.new([basename,extname])#readformURIintotempfileuri=URI.parse(file_url)num_bytes_writen=file.write(uri.read)puts"Wrote#{num_bytes_writen}bytes"#Readingfrommytempfileputs"

带有字符串参数的 Ruby grep

我想将grep与字符串一起用作正则表达式模式。我该怎么做?例子:myArray.grep(/asd/i)#Worksperfectly.但我想先准备好我的声明searchString='/asd/i'myArray.grep(searchString)# Fails我怎样才能做到这一点?我需要准备一个字符串,因为这将进入搜索算法,并且查询将根据每个请求进行更改。谢谢。 最佳答案 正则表达式支持插值,就像字符串一样:var="hello"re=/#{var}/ipre#=>/hello/i

Ruby 将字符串编码从 ISO-8859-1 转换为 UTF-8 不起作用

我正在尝试将字符串从ISO-8859-1编码转换为UTF-8,但似乎无法正常工作。这是我在irb中所做的示例。irb(main):050:0>string='Norrlandsvägen'=>"Norrlandsvägen"irb(main):051:0>string.force_encoding('iso-8859-1')=>"Norrlandsv\xC3\xA4gen"irb(main):052:0>string=string.encode('utf-8')=>"Norrlandsvägen"我不确定为什么iso-8859-1中的Norrlandsvägen会被转换为utf-8中

ruby - 拆分字符串抑制所有空字段

我想拆分一个抑制所有空字段的字符串命令:",1,2,,3,4,,".split(',')结果:["","1","2","","3","4",""]预期:["1","2","3","4"]如何做到这一点?编辑好的。只是总结所有发布的好问题。我想要的是split方法(或其他方法)不生成空字符串。看起来这是不可能的。因此,解决方案是两步过程:像往常一样拆分字符串,然后以某种方式从结果数组中删除空字符串。第二部分正是thisquestion(及其duplicate)所以我会用",1,2,,3,4,,".split(',').delete_if(&:empty?)NikitaRybak和user

Ruby 1.8.7 将散列转换为字符串

我没有使用ruby​​1.8.7,最近我很惊讶:{:k=>30}.to_s#=>"k30"是否准备好使用fix将哈希转换为ruby​​1.8.7的字符串以使其看起来像:{:k=>30}.to_s#=>"{:k=>30}" 最佳答案 hash.to_s确实已从1.8.7更改为1.9.3。在1.8.7中,(引用:http://ruby-doc.org/core-1.8.7/Hash.html#method-i-to_s):Convertshshtoastringbyconvertingthehashtoanarrayof[key,val