鱼C论坛

 找回密码
 立即注册
查看: 1036|回复: 4

[已解决]字符串分割求助。

[复制链接]
发表于 2022-8-12 11:45:53 | 显示全部楼层 |阅读模式
60鱼币
本帖最后由 小栗子 于 2022-8-12 11:46 编辑

QQ图片20220812114055.png
QQ图片20220812114055.png
如何获取红框中的数值

以下是返回的字符串实际值


"EA" & vbCrLf & "DATE 22/08/12" & vbCrLf & "TIME 11:45:57.300 " & vbCrLf & "E 0301    ??C       +99999999E-01" & vbCrLf & "E 0302    ??C       +99999999E-01" & vbCrLf & "E 0303    ??C       +99999999E-01" & vbCrLf & "E 0304    ??C       +99999999E-01" & vbCrLf & "E 0305    ??C       +99999999E-01" & vbCrLf & "E 0306    ??C       +99999999E-01" & vbCrLf & "E 0307    ??C       +99999999E-01" & vbCrLf & "E 0308    ??C       +99999999E-01" & vbCrLf & "E 0309    ??C       +99999999E-01" & vbCrLf & "E 0310    ??C       +99999999E-01" & vbCrLf & "O 0401    ??C       -99999999E-01" & vbCrLf & "N 0402    V         +00000000E-04" & vbCrLf & "N 0403    V         +00000000E-04" & vbCrLf & "N 0404    V         +00000001E-04" & vbCrLf & "N 0405    V         +00000001E-04" & vbCrLf & "N 0406    V         +00000001E-04" & vbCrLf & "N 0407    V         +00000001E-04" & vbCrLf & "N 0408    V         +00000001E-04" & vbCrLf & "N 0409    V         +00000001E-04" & vbCrLf & "N 0410    V         +00000001E-04" & vbCrLf & "N 0501    ??C       -00000611E-01" & vbCrLf & "N 0502    V         +00000000E-04" & vbCrLf & "N 0503    V         +00000000E-04" & vbCrLf & "N 0504    V         +00000000E-04" & vbCrLf & "N 0505    V         +00000000E-04" & vbCrLf & "N 0506    V         +00000000E-04" & vbCrLf & "N 0507    V         +00000001E-04" & vbCrLf & "N 0508    V         +00000001E-04" & vbCrLf & "EN" & vbCrLf


最佳答案
2022-8-12 11:45:54
写个正则表达式来匹配
import re

value = '"EA" & vbCrLf & "DATE 22/08/12" & vbCrLf & "TIME 11:45:57.300 " & vbCrLf & "E 0301    ??C       +99999999E-01" & vbCrLf & "E 0302    ??C       +99999999E-01" & vbCrLf & "E 0303    ??C       +99999999E-01" & vbCrLf & "E 0304    ??C       +99999999E-01" & vbCrLf & "E 0305    ??C       +99999999E-01" & vbCrLf & "E 0306    ??C       +99999999E-01" & vbCrLf & "E 0307    ??C       +99999999E-01" & vbCrLf & "E 0308    ??C       +99999999E-01" & vbCrLf & "E 0309    ??C       +99999999E-01" & vbCrLf & "E 0310    ??C       +99999999E-01" & vbCrLf & "O 0401    ??C       -99999999E-01" & vbCrLf & "N 0402    V         +00000000E-04" & vbCrLf & "N 0403    V         +00000000E-04" & vbCrLf & "N 0404    V         +00000001E-04" & vbCrLf & "N 0405    V         +00000001E-04" & vbCrLf & "N 0406    V         +00000001E-04" & vbCrLf & "N 0407    V         +00000001E-04" & vbCrLf & "N 0408    V         +00000001E-04" & vbCrLf & "N 0409    V         +00000001E-04" & vbCrLf & "N 0410    V         +00000001E-04" & vbCrLf & "N 0501    ??C       -00000611E-01" & vbCrLf & "N 0502    V         +00000000E-04" & vbCrLf & "N 0503    V         +00000000E-04" & vbCrLf & "N 0504    V         +00000000E-04" & vbCrLf & "N 0505    V         +00000000E-04" & vbCrLf & "N 0506    V         +00000000E-04" & vbCrLf & "N 0507    V         +00000001E-04" & vbCrLf & "N 0508    V         +00000001E-04" & vbCrLf & "EN" & vbCrLf'
valueList = re.findall("[+-][0-9]+E-[0-9]+",value)

print(valueList)

最佳答案

查看完整内容

写个正则表达式来匹配
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-8-12 11:45:54 | 显示全部楼层    本楼为最佳答案   
写个正则表达式来匹配
import re

value = '"EA" & vbCrLf & "DATE 22/08/12" & vbCrLf & "TIME 11:45:57.300 " & vbCrLf & "E 0301    ??C       +99999999E-01" & vbCrLf & "E 0302    ??C       +99999999E-01" & vbCrLf & "E 0303    ??C       +99999999E-01" & vbCrLf & "E 0304    ??C       +99999999E-01" & vbCrLf & "E 0305    ??C       +99999999E-01" & vbCrLf & "E 0306    ??C       +99999999E-01" & vbCrLf & "E 0307    ??C       +99999999E-01" & vbCrLf & "E 0308    ??C       +99999999E-01" & vbCrLf & "E 0309    ??C       +99999999E-01" & vbCrLf & "E 0310    ??C       +99999999E-01" & vbCrLf & "O 0401    ??C       -99999999E-01" & vbCrLf & "N 0402    V         +00000000E-04" & vbCrLf & "N 0403    V         +00000000E-04" & vbCrLf & "N 0404    V         +00000001E-04" & vbCrLf & "N 0405    V         +00000001E-04" & vbCrLf & "N 0406    V         +00000001E-04" & vbCrLf & "N 0407    V         +00000001E-04" & vbCrLf & "N 0408    V         +00000001E-04" & vbCrLf & "N 0409    V         +00000001E-04" & vbCrLf & "N 0410    V         +00000001E-04" & vbCrLf & "N 0501    ??C       -00000611E-01" & vbCrLf & "N 0502    V         +00000000E-04" & vbCrLf & "N 0503    V         +00000000E-04" & vbCrLf & "N 0504    V         +00000000E-04" & vbCrLf & "N 0505    V         +00000000E-04" & vbCrLf & "N 0506    V         +00000000E-04" & vbCrLf & "N 0507    V         +00000001E-04" & vbCrLf & "N 0508    V         +00000001E-04" & vbCrLf & "EN" & vbCrLf'
valueList = re.findall("[+-][0-9]+E-[0-9]+",value)

print(valueList)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-8-12 12:31:44 | 显示全部楼层
临时号 发表于 2022-8-12 11:57
写个正则表达式来匹配

大佬  用C#怎么解析啊?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-8-12 12:47:52 | 显示全部楼层
小栗子 发表于 2022-8-12 12:31
大佬  用C#怎么解析啊?

一样,很多语言都支持
using System;
using System.Text.RegularExpressions;

namespace RegExApplication
{
    class Program
    {
        static void Main(string[] args)
        {
            string value = ""EA" & vbCrLf & "DATE 22/08/12" & vbCrLf & "TIME 11:45:57.300 " & vbCrLf & "E 0301    ??C       +99999999E-01" & vbCrLf & "E 0302    ??C       +99999999E-01" & vbCrLf & "E 0303    ??C       +99999999E-01" & vbCrLf & "E 0304    ??C       +99999999E-01" & vbCrLf & "E 0305    ??C       +99999999E-01" & vbCrLf & "E 0306    ??C       +99999999E-01" & vbCrLf & "E 0307    ??C       +99999999E-01" & vbCrLf & "E 0308    ??C       +99999999E-01" & vbCrLf & "E 0309    ??C       +99999999E-01" & vbCrLf & "E 0310    ??C       +99999999E-01" & vbCrLf & "O 0401    ??C       -99999999E-01" & vbCrLf & "N 0402    V         +00000000E-04" & vbCrLf & "N 0403    V         +00000000E-04" & vbCrLf & "N 0404    V         +00000001E-04" & vbCrLf & "N 0405    V         +00000001E-04" & vbCrLf & "N 0406    V         +00000001E-04" & vbCrLf & "N 0407    V         +00000001E-04" & vbCrLf & "N 0408    V         +00000001E-04" & vbCrLf & "N 0409    V         +00000001E-04" & vbCrLf & "N 0410    V         +00000001E-04" & vbCrLf & "N 0501    ??C       -00000611E-01" & vbCrLf & "N 0502    V         +00000000E-04" & vbCrLf & "N 0503    V         +00000000E-04" & vbCrLf & "N 0504    V         +00000000E-04" & vbCrLf & "N 0505    V         +00000000E-04" & vbCrLf & "N 0506    V         +00000000E-04" & vbCrLf & "N 0507    V         +00000001E-04" & vbCrLf & "N 0508    V         +00000001E-04" & vbCrLf & "EN" & vbCrLf";
            MatchCollection mc = Regex.Matches(value, "[+-][0-9]+E-[0-9]+");
            foreach (Match m in mc)
            {
                Console.WriteLine(m);
            }
        }
    }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-8-12 22:11:00 | 显示全部楼层
临时号 发表于 2022-8-12 12:47
一样,很多语言都支持

嗯嗯 已经解决的  非常感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-15 17:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表