草庐IT

lambda表达式

全部标签

golang 中所有 url 的 Markdown url 的正则表达式

我正在尝试处理Markdown文件,替换所有图像url。markdown图片url的格式是![alternativename](imageurl.png)我的正则表达式搜索找到第一个,返回位置并替换它,然后我循环浏览文档直到我的正则表达式搜索没有找到任何-即它的匹配维度数组为空。问题是出于某种原因它继续匹配“我不完全知道是什么”。即从正则表达式搜索返回的数组的长度永远不会为0location:=split[:locationSplit]bodyRe:=regexp.MustCompile(`!\[(.*)\]\((.*)\)`)indexes:=bodyRe.FindStringInd

Golang 中的正则表达式命名组未正确捕获

我有以下字符串,它是来self们网络上投影仪的发现数据包:AMXB我正在尝试编写一些Golang代码将其转换为map,因此我可以调用details["UUID"]并让它返回ABCDEFG.我写了一个如下所示的正则表达式:(?:UUID=)(?P(.*?))>|(?:Make=)(?P(.*?))>|(?:Model=)(?P(.*?))>|(?:SDKClass=)(?P(.*?))>当我使用regex101在线测试它时,它似乎可以很好地匹配所有内容,除了编号的组,但我可以很容易地忽略这些:MATCH1SDKClass[15-29]VideoProjector[15-29]VideoP

regex - 微调正则表达式

我正在使用go中的一些正则表达式,这不是一个直接的过程,即需要时间来完成和理解我找到的项目并快速阅读手册;任何关于改进以下内容的意见都将不胜感激,以加快这一进程。//{aa,bb,cc,dd,etc.},{a+,b+,c+}regexp.MustCompile(`\B\{([\w-]+)(.*,)([\w-]+)(?:,[\w-]+=[\w-]+)*\}`)//abovecaptures{a+,b+,c},butnot{a+,b+,c+}//{1-9},{1-9,10,19,20-52}regexp.MustCompile(`\B\{([\d]?)-([\d]?)(?:,[\d]?=[

go - 如何使用正则表达式匹配任何重复字符?

我需要匹配任何重复两次的字符,例如:"abccdeff"应该匹配“cc”和“ff”。在任何其他正则表达式语法中,让我们使用Javascript作为一个快速示例,我可以这样做:varstr="abccdeff";varr=/([a-z]{1})\1/gconsole.log(str.match(r))哪个返回['cc','ff']但是Go的正则表达式似乎不允许这样做。可以在Go中执行此操作吗? 最佳答案 因为反向引用是notsupportedbyre2,你需要:要么使用anotherregexlibrary(比如glenn-brown

带有inotifywait的正则表达式在golang中编译两种类型的文件

我使用script使用inotifywait在golang中自动编译。但是这个脚本只检查扩展名为.go的文件。我还想添加.tmpl扩展名,但脚本使用正则表达式。我必须对此行进行哪些更改才能获得所需的结果?inotifywait-q-m-r-eclose_write-emoved_to--exclude'[^g][^o]$'$1我试过连接|或&和其他类似([^t][^m][^p][^l]|[^g][^o])$但似乎没有任何效果。 最佳答案 与其尝试使用正则表达式来排除两种类型的文件,不如只看那些文件?inotifywait-q-m-r

Golang 中的正则表达式 : How to set character that makes the string not match?

我对正则表达式一窍不通(抱歉)。我试图制作一种非常简单的标记语言,匹配粗体和斜体,然后将它们转换为HTML。这是我使用的粗体示例:varbold=regexp.MustCompile("\\*([^\\*]+)\\*")它匹配两个星号之间的所有内容。现在,我希望它匹配*test*但不匹配\*test*。由于我对正则表达式知之甚少,但我正在尝试进行此实验,因此我想知道这样做的方法是什么。我到处搜索,但找不到完成这项工作的方法。 最佳答案 已更新Go不支持回顾。因此,解决方法可以是:(?:\A|(?:[^\\]+|\A)(\\{2})+

c# - 如何将整个字符串与正则表达式匹配?

我需要一个正则表达式,它只会找到整个字符串与我的查询匹配的匹配项。例如,如果我搜索名称为“RedOctober”的电影,我只想匹配确切的标题(不区分大小写),而不匹配“TheHuntForRedOctober”等标题。不太确定我知道该怎么做。有人知道吗?谢谢! 最佳答案 试试下面的正则表达式:^RedOctober$默认情况下,正则表达式区分大小写。^标记匹配文本的开始,$标记结束。 关于c#-如何将整个字符串与正则表达式匹配?,我们在StackOverflow上找到一个类似的问题:

regex - 是否去正则表达式任何字符匹配换行符

Go的re2syntaxdocument表示任何字符(.)匹配任何字符,包括换行符(s=true)。但是我写了一个简单的程序结果显示任何字符根本不匹配换行符。该程序可以在这里找到:http://play.golang.org/p/pccP52RvKS 最佳答案 与大多数其他(所有?)正则表达式引擎一样,点不匹配换行符,除非你将“全部点”标记(?s)添加到正则表达式。我使用您的链接对此进行了测试并且有效。https://golang.org/pkg/regexp/syntax 关于rege

email - 在网站中匹配正则表达式电子邮件

我尝试在goland的网站中使用文件包含url查找电子邮件匹配项,例如,如果我在文件中放入“http://facebook.com”,他将尝试在网站中查找所有电子邮件,但他总是结果0。我想我选择了错误的功能,但我试图找到其他功能,但我得到了相同的结果。这里的代码:packagemainimport("bufio""bytes""fmt""log""net/http""os""regexp""sync")funcmain(){varwgsync.WaitGroupwg.Add(1)goemailWeb(os.Args[1],&wg)wg.Wait()}funcemailWeb(names

regex - 去正则表达式 : how I can replace named groups by concrete values in source pattern?

也许,你可以帮我。例如,我有像(?P\w+)(?P\w+)这样的正则表达式.我如何使用map[string]string{"name":"Alice","surname":"Cool"}替换组以获得字符串AliceCool?这可能吗?谢谢。 最佳答案 好的,我找到了制作方法。希望它会对某人有所帮助。https://play.golang.org/p/Xz9PtE_bIt 关于regex-去正则表达式:howIcanreplacenamedgroupsbyconcretevaluesins