草庐IT

regex_search

全部标签

regex - 是否可以在 Golang 中提取字符串的一部分并在一次操作中替换这些部分?

假设我想从一个字符串中提取所有数字(很可能使用正则表达式匹配)并且我还想用通用占位符(如“#”)替换这些数字匹配。这很容易分两部分完成,先使用FindAll,然后使用ReplaceAll。但是,我对执行此类操作的性能成本深表怀疑。所以取一个字符串"sdasd3.2%sadas6...+8.9"替换为"sdasd#%sadas#...+#"得到一片[3.2,6.0,8.9]以尽可能高效的方式。编辑:我实现了regexp.FindAllString+regexp.ReplaceAllString并且对我的应用程序的性能影响非常小。我希望有空时尝试ElliotChance的方法并比较两者。

regex - Go validator.v2 为正则表达式给出错误 "unknown tag"

我一直在努力理解为什么一些正则表达式在使用validator.v2时给我一个错误“Unknowntag”在golang中打包。它适用于某些正则表达式,但不适用于其中包含“{}”的某些正则表达式,并且当我使用validator.Validate()时,它在运行时给我一个错误“未知标记”。代码如下:typeCompanystruct{Namestring`validate:"regexp=^[a-zA-Z.]{1,100}$"`}这在运行时给我以下错误:Name:unknowntag但是这个正则表达式工作得很好typeCompanystruct{Namestring`validate:"r

regex - 去正则表达式不匹配

我正在尝试从自定义负载中提取JSON对象。我的正则表达式在这里工作正常:https://regex101.com/r/G5lBDC/1/但是Go没有返回任何匹配项re:=regexp.MustCompile(`/payload:\\"(.+?)\\\\\\"\\\\/g`)rawResponse:="version:1response:"rawJSON:=re.FindStringSubmatch(rawResponse)去Playgroundhttps://play.golang.org/p/XRfbExNa9V 最佳答案 你可以

elasticsearch - 并发文件解析并插入到 Elastic Search 中

我最近在玩Go,想出了一个小脚本来解析日志文件并将它们插入到Elasticsearch中。对于每个文件,我都生成了一个这样的goroutine:varwg:=sync.WaitGroup{}wg.Add(len(files))for_,file:=rangefiles{gofunc(fos.FileInfo){deferwg.Done()ProcessFile(f.Name(),config.OriginFilePath,config.WorkingFilePath,config.ArchiveFilePath,fmt.Sprintf("http://%v:%v",config.Ela

regex - Go:处理多行命令输出并解析

我正在尝试从命令行实用程序中提取信息,在本例中是linuxntpq-crv命令。输出:associd=0status=0638leap_none,sync_ntp,3events,no_sys_peer,version="ntpd4.2.6p5@1.2349-oFriJul2217:30:51UTC2016(1)",processor="x86_64",system="Linux/3.16.0-4-amd64",leap=00,stratum=2,precision=-22,rootdelay=25.435,rootdisp=49.398,refid=8.8.8.8,reftime=d

regex - 从捕获中排除符号并仅获取所需数据?

我有包含天、小时、分钟的文本,格式如下:4d.12h.32m.7h.22m.3d.14h.注意,其中一些可能不存在(例如:3d.14h.不包含分钟)我想捕获命名组中的数字,但不捕获字符(d.h.m.)。所以最后我需要得到类似这张map的结果:['days'=>4,'hours'=>12,'minutes'=>32,]这是我写的:(?P(\d+)d.)?(?P(\d+)h.)?(?P(\d+)m.)?链接:https://regex101.com/r/FERRnd/1但似乎有一些空元素,我觉得这不是完成这项任务的最佳正则表达式。有什么方法可以只接收命名参数作为数字而不是其他任何东西(没有

regex - 为什么 regexp.FindAllString 会返回带有不需要的空字符串的匹配结果?

这个问题在这里已经有了答案:Whatspecialcharactersmustbeescapedinregularexpressions?(12个答案)关闭5年前。有正则表达式:302\=.+?190\=(\d|\.)+|`这是要匹配的字符串:8=FIX.4.4|9=181|35=i|34=6|49=XCD1|52=20171025-08:33:56.791|56=Q142|296=3|302=5|295=1|299=0|188=0.74499|190=0.74549|302=4|295=1|299=0|188=0.74996|190=0.75026|302=3|295=1|299=0

rest - 在 Golang 中向 Splunk REST API/search/jobs/endpoint 发送查询

我想向SplunkRESTAPI发送搜索/查询,并返回搜索ID以供稍后使用结果。我可以通过以下curl实现所需的行为:#!/bin/bashuser='my_user'pass='my_pass'search='searchindex=shortsourcetype=src|head5'curl-u$user:$pass-khttps://111.22.33.44:8089/services/search/jobs-dsearch="$search"返回:234523452435.6556_234234-3J3J-34J4-2345-123456678E3以下是我试图在其中实现相同目标

regex - 解析参数列表中以逗号分隔的逗号分隔值

所以我有这个正则表达式:=([0-9A-Za-z_-]+),?我需要一个像这样的字符串:foo=bar,pine=apple,tree,bar=bieorfoo=bar,pine=apple,treeorpine=apple,tree正则表达式适用于我只有1个值的情况。但是因为我们在键的值列表中有逗号。正则表达式只是乱码,我的代码完成了我想要它做的一半,但没有获得第二个值。我如何修复我的正则表达式以获取两个值,而不管它在字符串中的位置?单独,在另外2个之间,最后。我尝试了一些东西,但无法弄明白。尝试1:=([0-9A-Za-z,_-]+),=?在这种情况下,它匹配它在中间的那个,但它在

regex - 为什么我的正则表达式不匹配并替换字符串以将 urlencode 转换为新字符串?

我卡住了,不明白为什么会出问题。它应该匹配“-_”的正则表达式并替换为“%/”。packagemainimport("fmt""regexp")funcmain(){rewrittenUrl:="https://rewriteurls.com/v2/url?u=https-3A__www.youtube.com_watch-3Fv-3D4RkZAfD-2JHeM&d=DwMFaQ&c=SiTLKJfsN-8Sb-MxLIXcbA&r=LqnK821DYMk9rZdGgNQw73sPqZUvbX2xxnSU9Ro3lk8&m=Qq7De43ipEDY9RFTKIoH6VpjqxPwG1A