登录
首页 >  Golang >  Go问答

Golang会在没有缩进的情况下分割字符串

来源:stackoverflow

时间:2024-02-09 14:30:26 289浏览 收藏

Golang不知道大家是否熟悉?今天我将给大家介绍《Golang会在没有缩进的情况下分割字符串》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

问题内容

我有一个这样的日志文件。

info [com.cplus.sdk.iso.module] 02:55:24.8290 19.02.2022 @ com.cplus.sdk.iso.module
  [message] message sent
  [source] [protocol:tranzware-interconnect (v.2.115-11);client:[transport:tcp/ip;to:/127.0.0.1:50274;from:/127.0.0.1:4455;keepalive:true;framer:l2 l1 <###>]]
  [thread] ia-pool-thread-18 (30)
info [com.cplus.sdk.net] 02:55:25.7840 19.02.2022 @ com.cplus.sdk.net.client
  [message] connection closed
  [source] [transport:tcp/ip;closed;to:/172.30.250.35:57001;from:/10.1.180.54:49851;keepalive:true;framer:(len+1) l2 l1 <###> etx]
  [thread] ia-pool-thread-4 (16)
severe [com.cplus.ia] 02:55:25.9530 19.02.2022 @ com.cplus.ia.instance$interfacelistener$2
  [message] interface processing error
  [source] instance:[unitid:11276;external:{externalhost:[protocol:alto-rtt (v.1.0);interface:iso-8583 based host-to-host interface]}]
  [thread] ia-pool-thread-4 (16)
  [exception] com.cplus.sdk.ex.processorexception com.cplus.ia.tic.interface.handle <- com.cplus.sdk.iso.processor.process <- com.cplus.ia.tic.interface.process <- com.cplus.sdk.iso.module.process <- com.cplus.ia.instance$interfacelistener$2.run <- java.util.concurrent.executors$runnableadapter.call[executors.java<511>] <- java.util.concurrent.futuretask.run[futuretask.java<266>] <- java.util.concurrent.threadpoolexecutor.runworker[threadpoolexecutor.java<1149>] <- java.util.concurrent.threadpoolexecutor$worker.run[threadpoolexecutor.java<624>] <- com.cplus.ia.instance$applicationthread.run <- java.lang.thread.run[thread.java<748>]
    [text] unhandled processing error
    [cause] com.cplus.sdk.ex.networkexception com.cplus.sdk.iso.module.send <- com.btpn.alto.rtt.ticinterface.msghandler[ticinterface.java<329>] <- com.btpn.alto.rtt.ticinterface.onfinancial[ticinterface.java<183>] <- com.cplus.ia.tic.interface.handle <- com.cplus.sdk.iso.processor.process <- com.cplus.ia.tic.interface.process <- com.cplus.sdk.iso.module.process <- com.cplus.ia.instance$interfacelistener$2.run <- java.util.concurrent.executors$runnableadapter.call[executors.java<511>] <- java.util.concurrent.futuretask.run[futuretask.java<266>] <- java.util.concurrent.threadpoolexecutor.runworker[threadpoolexecutor.java<1149>] <- java.util.concurrent.threadpoolexecutor$worker.run[threadpoolexecutor.java<624>] <- com.cplus.ia.instance$applicationthread.run <- java.lang.thread.run[thread.java<748>]
      [cause] java.nio.channels.interruptedbytimeoutexception com.cplus.sdk.net.frameshelper.checkdeadline <- com.cplus.sdk.net.frameshelper$io.write <- com.cplus.sdk.net.frames$frame27.write <- com.cplus.sdk.net.client.write <- com.cplus.sdk.iso.module$moduletcp.sendmessage <- com.cplus.sdk.iso.module.send <- com.btpn.alto.rtt.ticinterface.msghandler[ticinterface.java<329>] <- com.btpn.alto.rtt.ticinterface.onfinancial[ticinterface.java<183>] <- com.cplus.ia.tic.interface.handle <- com.cplus.sdk.iso.processor.process <- com.cplus.ia.tic.interface.process <- com.cplus.sdk.iso.module.process <- com.cplus.ia.instance$interfacelistener$2.run <- java.util.concurrent.executors$runnableadapter.call[executors.java<511>] <- java.util.concurrent.futuretask.run[futuretask.java<266>] <- java.util.concurrent.threadpoolexecutor.runworker[threadpoolexecutor.java<1149>] <- java.util.concurrent.threadpoolexecutor$worker.run[threadpoolexecutor.java<624>] <- com.cplus.ia.instance$applicationthread.run <- java.lang.thread.run[thread.java<748>]
fine [com.cplus.sdk.net] 05:27:34.0200 27.03.2022 @ com.cplus.sdk.net.client
  [message] frame sent: qtrnmtawmdawodawodiymdawmdawmdawmdawmda0mdawmdawmdawmdawmdawmzi2mjiynzm0mzawnzkzmzax
  [source] [transport:tcp/ip;to:/127.0.0.1:56573;from:/127.0.0.1:2221;keepalive:true;framer:l2 l1 <###>]
  [thread] ia-pool-thread-2 (45)
info [com.cplus.sdk.iso.module] 05:27:34.0200 27.03.2022 @ com.cplus.sdk.iso.module
  [message] message sent
  [source] [protocol:tranzware-interconnect (v.2.115-11);client:[transport:tcp/ip;to:/127.0.0.1:56573;from:/127.0.0.1:2221;keepalive:true;framer:l2 l1 <###>]]
  [thread] ia-pool-thread-2 (45)

我想根据下一行是否不是 \t 字符来对其进行拆分和分组。在javascript中,我可以在 split 方法中使用正则表达式,但是 golang split in strings 内置函数仅接收字符串作为分隔符。到目前为止我尝试过的是

strings.SplitAfter(log, ")")

但是上面的代码并没有完全捕获 severe 状态。 我正在考虑循环遍历每个字符并查找字母字符并将其附加到切片中,但我认为它会太慢。 有什么办法可以做到吗?


正确答案


如果需要,您可以使用正则表达式来执行此操作;像下面这样的东西应该可以工作playground

regexp.MustCompile("([^ ].*[\r|\n].(?: .*[\r|\n]*)*)").FindAllString(input, -1)

(请注意,上面使用空格而不是制表符,因为这是我从您的问题复制数据时得到的)。

或者您可以编写自己的代码;标准库的来源是 good starting point

今天关于《Golang会在没有缩进的情况下分割字符串》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>