草庐IT

html - 正则表达式替换 html 标签外的文本

全部标签

ruby - 为什么这两个不同的正则表达式根据下划线的位置在 Ruby 中返回不同的结果

我有以下内容:.[11]pry(main)>"abBN123-4.56".scan(/BN([0-9_\.-]+)/)=>[["123-4.56"]][12]pry(main)>"abBN123-4.56".scan(/BN([0-9\.-_]+)/)=>[["123"]]我不确定为什么第二个末尾带有下划线的行为与第一个行为不同。RegEx解析器如何解释它以使其不同? 最佳答案 这是因为您将连字符(-)放在了字符类的中间而没有被转义。在字符类[]中,您可以放置​​一个连字符(-)作为first或last性格。如果您将连字符放在其他任

ruby - ruby 中可以匹配任何表情符号的正则表达式示例是什么?

我需要使用正则表达式在Ruby中匹配字符串中的表情符号。我已经尝试了几个unicode序列,但似乎没有一个能完全胜任。我也不确定表情符号的开始和结束范围在哪里。 最佳答案 这个正则表达式匹配所有845个表情符号,取自Emojiunicodecharactersforuseontheweb:[\u{203C}\u{2049}\u{20E3}\u{2122}\u{2139}\u{2194}-\u{2199}\u{21A9}-\u{21AA}\u{231A}-\u{231B}\u{23E9}-\u{23EC}\u{23F0}\u{23F3

ruby - 如何分隔 DynamoDB 更新表达式中的多个子句

根据AWSDocs:Anupdateexpressionconsistsofoneormoreclauses.EachclausebeginswithaSET,REMOVE,ADDorDELETEkeyword.Youcanincludeanyoftheseclausesinanupdateexpression,inanyorder.However,eachactionkeywordcanappearonlyonce.我无法在一个update_expression中获得正确的SET和REMOVE语法:params={key:{'id'=>{s:'123'}},table_name:'c

ruby-on-rails - 在 Rails 中,如何使用字符串数组实现 HTML 选择菜单?

我有一个FinancialDocument#document_type模型属性。我想让用户从由字符串数组填充的HTML选择菜单中选择文档类型...doctypes=['Invoice','Packingslip','Other']对于每个选项,显示的标签和返回的值都是相同的。我查看了select和collection_select助手,但它们似乎适合选择子模型,而不仅仅是一个String值。我找不到如何让它们达到我的目的。这是我正在尝试的方法(我使用的是Haml,而不是Erb)...form_for(@financial_document)do|f|-doctypes=['Invoic

ruby - 您是否已将 makefile 替换为 ruby​​ 脚本?

我很欣赏makefile和make的所有荣耀,但我想知道是否有更直观的方法来维护我的c/c++构建。有没有人尝试过用ruby​​脚本替换他们的makefile以允许在不牺牲可读性的情况下进行复杂和自适应的构建?是否有使这更容易的gem? 最佳答案 看看Rake,用Ruby编写的make替代品。它基本上是一种小型领域特定语言,适用于典型的make类任务,可以在Rakefile中编写普通的ruby​​代码。 关于ruby-您是否已将makefile替换为ruby​​脚本?,我们在StackO

ruby - 在 Ruby 中使用 Nokogiri 解析 HTML

使用此HTML代码:....................如何使用Nokogiri选择类为1的第二个或第三个div? 最佳答案 您可以使用Ruby将大型结果集缩减为特定项目:page.css('div.one')[1,2]#Twoitemsstartingatindex1(2nditem)page.css('div.one')[1..2]#Itemswithindicesbetween1and2,inclusive因为Ruby索引从零开始,所以你必须注意你想要的项目。或者,您可以使用CSS选择器来查找nthitem:#Second

ruby 正则表达式扫描与 =~

Ruby(1.9.3)文档似乎暗示scan等同于=~除了scan返回多个匹配项,而=~仅返回第一个匹配项,并且scan返回匹配数据,而=~返回索引。但是,在下面的示例中,这两种方法似乎对相同的字符串和表达式返回不同的结果。这是为什么?1.9.3p0:002>str="PerlandPython-thetwolanguages"=>"PerlandPython-thetwolanguages"1.9.3p0:008>exp=/P(erl|ython)/=>/P(erl|ython)/1.9.3p0:009>str=~exp=>01.9.3p0:010>str.scanexp=>[["er

ruby - 反斜杠 + Ruby 正则表达式中的捕获组

如何在捕获的组之前取消反斜杠?例子:"foo+bar".gsub(/(\+)/,'\\\1')我期望(和想要)的:foo\+bar我不幸得到了什么:foo\\1bar我如何正确地逃离这里? 最佳答案 正如其他人所说,您需要将该字符串中的所有内容转义两次。因此,在您的情况下,解决方案是使用'\\\\\\1'或'\\\\\\1'。但既然你问为什么,我会试着解释那部分。原因是替换序列被解析了两次——一次由Ruby解析,一次由底层正则表达式引擎解析,其中\1是它自己的转义序列。(使用双引号字符串可能更容易理解,因为单引号引入了歧义,其中'\

ruby - 使用正则表达式获取 URL 的域

我正在尝试获取给定URL的域。例如http://www.facebook.com/someuser/将返回facebook.com。给定的URL可以是以下格式:https://www.facebook.com/someuser(www.是可选的,但应忽略)www.facebook.com/someuser(http://不是必需的)facebook.com/someuserhttp://someuser.tumblr.com->这只能返回tumblr.com我写了这个正则表达式:/(?:\.|\/{2})(?:www\.)?([^\/]*)/i但它并没有像我预期的那样工作。我可以分部分

ruby-on-rails - Rails 3 和 PDFKit,如何将 HTML 文件转换为横向 PDF?

我可以很好地将HTML页面转换为PDF文档。问题是,我不知道如何将HTML文件转换为横向PDF。有没有办法在Controller中设置它?从Controller...defpdf_customer_shipments@customer=Customer.find(params[:id])@shipments=Shipment.where("customer_id=?ANDstatus='Open'",@customer.id)render:layout=>'pdf'end 最佳答案 如果这有帮助,我正在使用PDFKit,并且可以使用