草庐IT

go - 从包导入路径获取包源的完整路径

全部标签

ruby - 在 Ruby 中获取调用者的模块

我们有代码在我们的Ruby1.8.6网络应用程序中记录数据。你大致这样调用它:$log.info("Sometexthere")现在,在记录的输出中,我想包括该行出现的模块。我知道Kernel#caller会给我一个数组,我可以在其中提取日志行出现的文件和行号,但我不希望这样。我想要模块,而不是文件名。显而易见的解决方案是修改日志行,使其如下所示:$log.info("Sometexthere",self.class.name)然后解析结果。不过,这行不通,因为我试图在默认情况下提取此信息。也就是说,如果程序员忘记指定模块(日志行的第二个参数),我需要解决方案。有什么办法吗?如果没有,

Ruby 相当于 "grep -C 5"以获取匹配项周围的行的上下文?

我搜索了一下,但我一定是使用了错误的术语-ruby​​是否有办法grep查找字符串/正则表达式并返回周围的5行(上方和下方)?我知道我可以调用"grep-C5..."或什至编写我自己的方法,但这似乎是ruby​​应该有的东西,我只是没有使用正确的搜索词。 最佳答案 您可以使用正则表达式来完成。这是我们要搜索的字符串:s=%{ThefirstlineThesecondlineThethirdlineThefourthlineThefifthlineThesixthlineTheseventhlineTheeightlineThenin

ruby - 如何使用Nokogiri和XPath获取具有多个属性的节点

我正在尝试使用Nokogiri来解析带有一些相当古怪的标记的HTML文件。具体来说,我正在尝试获取同时定义了id、多个类和样式的div。标记看起来像这样:titleListofstuff我正在尝试获取里面的问题.我可以毫无问题地获得具有单个id属性的div,但我想不出一种方法让Nokogiri获取具有和两个id类的div。所以这些工作正常:content=@doc.xpath("//div[id='foo']")content=@doc.css('div#foo')但是这些不返回任何东西:content=@doc.xpath("//div[id='bar']")content=@doc

ruby-on-rails - 使用载波获取gif中的第一张图像

我使用载波上传gif效果很好,当我尝试生成拇指版本并将gif转换为jpeg时出现问题,只有gif中的第一张图像作为拇指,我得到一个错误:LocalJumpErrorinImagesController#createnoblockgiven(yield)app/controllers/images_controller.rb:21:in`new'app/controllers/images_controller.rb:21:in`create'请求参数:{"utf8"=>"✓","authenticity_token"=>"lPEjP1WtPxFdizL2/FAWGHzOZPtecb5n

ruby - 无法从 Jekyll 插件获取页面数据

我正在尝试为Jekyll编写一个自定义标签插件,它将输出站点上所有页面(不是帖子)的分层导航树。我基本上想要一堆嵌套的链接(以页面标题作为链接文本)指向具有特定CSS类标记的当前页面的页面。我对ruby​​非常缺乏经验。我是PHP专家。我想我应该从尝试遍历所有页面并输出一个一维列表开始,只是为了确保我至少可以做到这一点。这是我到目前为止所拥有的:moduleJekyllclassNavTree'site.pages.eachdo|page|output+=''+page.title+''endoutput+=''outputendendendLiquid::Template.regis

ruby - git:从 bitbucket 导出并导入 github(带提交)

我在bitbucket上创建了一个私有(private)git存储库并提交了代码。现在我想导出所有(提交、代码、历史记录)并将其导入github上的gitrepo。有没有办法做到这一点?谢谢 最佳答案 在本地检查所有内容到您的计算机和gitpull。创建一个github存储库将此存储库添加为您的第二个远程(“使用gitremote添加githubURL”)推送到第二个Remote 关于ruby-git:从bitbucket导出并导入github(带提交),我们在StackOverflow

ruby - 使用 Nokogiri 从 HTML 获取父元素

我有以下HTML,我想获取文档中的父项。我使用Nokogiri进行解析:j_text="abcpqr>examplefindbyIDzzzznnnnnsfds"我做到了:doc=Nokogiri::HTML(j_text)现在我想要来自HTML文本上方的父元素,即,,,使用Nokogiri,我该怎么做? 最佳答案 当您在Nokogiri中加载该HTML片段时,它会自动将元素插入到具有嵌套“body”元素的根级“html”元素中。因此,您提供的HTML片段中节点的父级将是“正文”:doc=Nokogiri::HTML(j_text)d

ruby-on-rails - 为 rails 中的 javascript 生成完整的 url(类似于 javascript_path,但是是 url)

如何生成指向javascript文件的绝对链接。我想应该有类似下面的东西(不幸的是它似乎不可用):javascript_url'main'#->'http://localhost:3000/javascripts/main.js'代替:javascript_path'main'#->'/javascripts/main.js'我需要绝对URL,因为该javascript文件将用于书签。另外我需要相同的css文件。谢谢,德米特里。 最佳答案 javascript和css文件的绝对URL现在在Rails4中可用ActionView::H

ruby - 如何不在 ruby​​ 中编写完整的模块路径?

假设我在一个非常长的模块路径中有一个类:sux=Really::Long::Module::Path::Sucks.new我能否以某种方式“导入”这个模块,这样我就可以直接使用这个类,而不必担心每次使用它时都要写这个路径?编辑:我知道在同一个模块中会让事情变得更容易。但在这种情况下,我不能在同一个模块中。 最佳答案 模块是ruby​​中的对象,因此您可以只引用较短的模块。Sux=Really::Long::Module::Path::SucksSux.new 关于ruby-如何不在rub

ruby-on-rails - 缓存 WSDL 文件而不是在每个 SOAP 请求时获取它

我正在构建一个Rails应用程序,该应用程序将基本上包含一组SOAP命令。我不想每次都获取WSDL来实现某种缓存方法,尽管我不太确定从哪里开始执行此操作。是否有特定于Rails的东西可以帮助我,或者我应该通过Ruby下载文件并加载它?只是在寻找某种总体方向...... 最佳答案 如果您使用savon然后是remoteWSDLwillbedownloadedonceperclientinstance:the(remote)WSDLhastobedownloadedandparsedonceforeveryclientandsocome