java解析器文件文本

时间:2016-03-01 09:44:00

标签: java mysql parsing

我有这个文本文件,我想解析并将其放入mysql数据库:

    A:PE9301_P# show port 1/1/1 
===============================================================================
Ethernet Interface
===============================================================================
Description        : PE9301_P:PE9148_P:01:10G
Interface          : 1/1/1                      Oper Speed       : 10 Gbps
Link-level         : Ethernet                   Config Speed     : N/A
Admin State        : up                         Oper Duplex      : full
Oper State         : up - Active in LAG 1       Config Duplex    : N/A
Physical Link      : Yes                        MTU              : 9212
Single Fiber Mode  : No                         Min Frame Length : 64 Bytes

我只想要那些信息: PE9301,up - 活跃于LAG 1 我无法找到解决方案帮助mz plz

1 个答案:

答案 0 :(得分:0)

使用以下正则表达式:

/Description\s+:\s([\w\s]+)/g

/Oper State\s+:\s(.{26,26})/g

如果要解析整个结构,请使用字符长度而不是正则表达式将结构拆分为键值数组,并将键与常量进行比较(“描述”,“操作状态”等等)< / p>

作为Java测试单元的工作示例:

private static final String NIFSOURCE = "A:PE9301_P# show port 1/1/1\r\n"+
        "===============================================================================\r\n"+
        "Ethernet Interface\r\n"+
        "===============================================================================\r\n"+
        "Description        : PE9301_P:PE9148_P:01:10G\r\n"+
        "Interface          : 1/1/1                      Oper Speed       : 10 Gbps\r\n"+
        "Link-level         : Ethernet                   Config Speed     : N/A\r\n"+
        "Admin State        : up                         Oper Duplex      : full\r\n"+
        "Oper State         : up - Active in LAG 1       Config Duplex    : N/A\r\n"+
        "Physical Link      : Yes                        MTU              : 9212\r\n"+
        "Single Fiber Mode  : No                         Min Frame Length : 64 Bytes";

/**
 * Ceci est un test que l'ont peut remplacer par une méthode Main ou une function 
 *                                                             - Uncle Bob Martin
 */
@Test
public void NIFParseTest() {
    String NIFdescription = null, NIFstate = null;

    Pattern motifRE = Pattern.compile("^Description\\s+:\\s(\\w+)", Pattern.MULTILINE);
    Pattern stateRE = Pattern.compile("^Oper State\\s+:\\s(.{26,26})", Pattern.MULTILINE | Pattern.UNIX_LINES);

    Matcher foundMatch = motifRE.matcher(NIFSOURCE);
    if (foundMatch.find()) {
        NIFdescription = foundMatch.group(1); //0 est la chaine complète, les motifs entre parenthèse sont disponibles à l'index 1
    }

    foundMatch = stateRE.matcher(NIFSOURCE);
    if (foundMatch.find()) {
        NIFstate = foundMatch.group(1);
    }
    assertNotNull(NIFdescription);
    assertNotNull(NIFstate);
}