草庐IT

符号计算

全部标签

c - 如何访问符号链接(symbolic link)的 ctime、mtime、...?

在unix上,符号链接(symboliclink)是指向另一个文件的指针。不仅文件而且符号链接(symboliclink)都有ctime、mtime、……。我知道可以访问符号链接(symboliclink)时间,因为ls显示了它。如果我使用ruby​​的File#ctime、File#mtime之一,我总是得到符号链接(symboliclink)指向的文件的属性,而不是符号链接(symboliclink)的属性。我如何在ruby​​中读取这些值?如果这在ruby​​中不可行,请告诉我如何在C中实现。在那种情况下我会编写自己的c扩展。 最佳答案

ruby - 使用符号读写 Sinatra 参数,例如参数[:id]

我的表单通过POST接收数据。当我执行putsparams时,我可以看到:{"id"=>"123","id2"=>"456"}现在是命令:putsparams['id']#=>123putsparams[:id]#=>123params['id']='999'putsparams#=>{"id"=>"999","id2"=>"456"}但是当我这样做的时候:params[:id]='888'putsparams我明白了{"id"=>"999","id2"=>"456",:id=>"888"}在IRB中它工作正常:params#=>{"id2"=>"2","id"=>"1"}params

ruby-on-rails - 如何复数 Ruby (on Rails) 中的符号?

这可行,但看起来有点丑:s=:shops.to_s.pluralize.to_sym#=>:shops有没有更好的方法来复数化Symbol? 最佳答案 您可以复数表示实际文本的String。符号有点抽象。所以,根据定义,不。但是,也许您可​​以打开Symbol类定义并添加:classSymboldefpluralizeto_s.pluralize.to_symendend然后,您可以调用::shop.pluralize#=>:shops 关于ruby-on-rails-如何复数Ruby(

ruby-on-rails - ruby 符号设置

我在我的代码中设置了如下符号:"name_of_symbol".to_sym但是,我的首席工程师在代码审查期间发现它是一种不好的做法,并要求我设置如下符号::"name_of_symbol"当我问他为什么?他说这是不好的做法,但是当我问他只是说这是什么原因时,这并不是一个令人满意的答案。所以怎么回事?有什么区别吗? 最佳答案 冒号表示一个符号。我不会将其称为非常规实践,而是糟糕的实践,这可能会使代码更难理解。我知道:"Someweird_stuff"是合法的,但我不喜欢它,就我个人而言,我宁愿使用:Some_weird_stuff并

ruby - 将正文拆分成句子但保留标点符号?

我正在尝试在2个html负载文本主体之间产生类似wiki的人类可读差异。我正在使用diff-lcs,第一步是将字符串(字符数组)分成句子数组,但保留标点符号。"Iamalion.Hearmeroar!Whereismycub?Nevermind,foundhim.".magic_split(/[.?!]/)#=>"Iamalion.""Hearmeroar!""Whereismycub?""Nevermind,foundhim."这应该可以解决问题"Iamalion.Hearmeroar!Whereismycub?Nevermind,foundhim.".gsub(/[.?!]/,'\

ruby - 在符号上链接 & to_proc

Rubyist众所周知,&会在符号上调用to_proc,所以[:a,:b,:c].map(&:to_s)相当于[:a,:b,:c].map{|e|e.to_s}#=>["a","b","c"]假设我想在to_s之后立即调用另一个方法,这两个实现将起作用:[:a,:b,:c].map{|e|e.to_s.upcase}[:a,:b,:c].map(&:to_s).map(&:upcase)我的问题是,有没有一种方法可以将&Symbol#to_proc调用链接到一个参数中?像这样的东西:[:a,:b,:c].map(&:to_s:upcase)谢谢! 最佳答案

ruby-on-rails - 我如何在 Ruby on Rails 中使用 GBP 英镑符号到货币方法?

我对Ruby和RubyonRails还很陌生。在按照Ruby指南创建小型寻食应用程序时,作者使用了RubyonRails中的数字到货币方法。问题是默认单位是$但我想将它更改为£。当我在其中执行此操作时,在我尝试运行代码后返回以下错误。number_helper.rb:7invalidmultibytechar(US-ASCII)(SyntaxError) 最佳答案 将以下内容放在文件的第一行您有£的地方。#coding:utf-8默认情况下,ruby可以读取一个字节的字符,即US-ASCIIcharacters。.£字符不适合US-

Ruby跨平台EOF符号的写法

在Ruby中是否有一种平台无关的方式将EOF符号写入字符串。在*nix中,我认为符号是^D,但在Windows中是^Z,这就是我问的原因。 最佳答案 EOF不是一个字符,它是一个状态。终端使用控制字符来表示此状态(C-d)。没有这样的事情是“读一个EOF字符”,写一个也是一样的。如果您正在写入文件,请在完成后将其关闭。看这个mailinglistpost:ItsoundslikeyouarethinkingofEOFasanin-bandbutspecialcharactervaluethatmarkstheendoffile.It

ruby - 使用 Ruby 作为脚本语言,使用 4gb RAM 的计算机对 30gb 的字符串进行排序的最佳方法是什么?

您好,我将其视为一个面试问题,并认为这是一个有趣的问题,但我不确定答案。最好的方法是什么? 最佳答案 假设*nix:system("sortoutput_file")“排序”可以使用临时文件来处理大于内存的输入文件。如果需要,它有开关来调整主内存的数量和它将使用的临时文件的数量。如果不是*nix,或者面试官因为斜着回答皱眉,那我就编码一个外部mergesort.请参阅@psyho的回答以获得外部排序算法的良好总结。 关于ruby-使用Ruby作为脚本语言,使用4gbRAM的计算机对30g

Ruby:计算二进制数中 1 的个数

我有一个表示为字符串“01100011....”的二进制数(52位)计算1的个数最快的方法是什么?"01100011....".count("1")显然有效,但如果此操作需要执行数千次,则非常耗时。好的,还有更多信息。我正在尝试为单词创建位向量,如下所示defbit_vec(str)alphabet='ABCDEFGHIJKLMNOPQRSTUVWXYZ'bv=""alphabet.each_chardo|a|ifstr.include?(a)bv+="1"elsebv+="0"endendbvendbit_vec方法被调用了大约17万次。我将位向量存储在哈希中,并使用它们通过对位向量