大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 Java正則表達式匹配字符串提取中間值

Java正則表達式匹配字符串提取中間值

更新時間:2021-05-06 11:51:57 來源:動力節點 瀏覽1390次

場景一:提取SAML2報文

SAML2報文內容如下,從中提取對應的attribute name和value.

<saml:AttributeStatement>
	<saml:Attribute Name="mail">
		<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">zhengkai.blog.csdn.net</saml:AttributeValue>
	</saml:Attribute>
	<saml:Attribute Name="cn">
		<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">amAdmin</saml:AttributeValue>
	</saml:Attribute>
</saml:AttributeStatement>

show time

public static void main(String[] args) {
		String content = "";
		content = "<saml:AttributeStatement>";
		content += "	<saml:Attribute Name=\"mail\">";
		content += "		<saml:AttributeValue xmlns:xs=\"http://www.w3.org/2001/XMLSchema\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xsi:type=\"xs:string\">zhengkai.blog.csdn.net</saml:AttributeValue>";
		content += "	</saml:Attribute>";
		content += "	<saml:Attribute Name=\"cn\">";
		content += "		<saml:AttributeValue xmlns:xs=\"http://www.w3.org/2001/XMLSchema\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xsi:type=\"xs:string\">amAdmin</saml:AttributeValue>";
		content += "	</saml:Attribute>";
		content += "</saml:AttributeStatement>";
		String pattern = "\\<saml\\:Attribute Name=\\\"(?<scope>.*?)\\\"\\>[\\s\\S]*?\\<saml\\:AttributeValue[\\s\\S]*?\\>(?<value>.*?)\\<\\/saml\\:AttributeValue\\>[\\s\\S]*?\\<\\/saml\\:Attribute\\>";
		Pattern r = Pattern.compile(pattern);
		Matcher matcher = r.matcher(saml2attributeString);
		while (matcher.find()){
			String attributeName = matcher.group("scope");
			String attributeValue = matcher.group("value");
			System.out.println("attributeName->"+attributeName +",attributeValue->"+attributeValue );
		}
	}

控制臺輸出

$ attributeName->mail,attributeValue->zhengkai.blog.csdn.net
$ vattributeName->cn,attributeValue->amAdmin

解析

\\<saml\\:Attribute Name=\\\"(?<scope>.*?)\\\"\\>[\\s\\S]*?\\<saml\\:AttributeValue[\\s\\S]*?\\>(?<value>.*?)\\<\\/saml\\:AttributeValue\\>[\\s\\S]*?\\<\\/saml\\:Attribute\\>

1.(?.*?)是用于標識scope的方式,表示夾在中間的字符串都叫scope,可以通過matcher.group("scope")提取。

2.所有非正則的符號都需要轉義,所以你會看到很多\\<或者換\\"之類的\\

3.[\\s\\S]*? 是用來匹配任意字符,表示在前后有界定的情況下(例如夾在中間的字符串),可以忽略那些不規則字符串的匹配。

場景2:提取sql中的表名和字段

    //匹配整個ddl,將ddl分為表名,列sql部分,表注釋
    private static final Pattern DDL_PATTERN = Pattern.compile("\\s*create\\s+table\\s+(?<tableName>\\S+)[^\\(]*\\((?<columnsSQL>[\\s\\S]+)\\)[^\\)]+?(comment\\s*(=|on\\s+table)\\s*'(?<tableComment>.*?)'\\s*;?)?$", Pattern.CASE_INSENSITIVE);
    //匹配列sql部分,分別解析每一列的列名 類型 和列注釋
    private static final Pattern COL_PATTERN = Pattern.compile("\\s*(?<fieldName>\\S+)\\s+(?<fieldType>\\w+)\\s*(?:\\([\\s\\d,]+\\))?((?!comment).)*(comment\\s*'(?<fieldComment>.*?)')?\\s*(,|$)", Pattern.CASE_INSENSITIVE);
    public static void parse(String sql){
        Matcher matcher = DDL_PATTERN.matcher(sql);
        if (matcher.find()){
            String tableName = matcher.group("tableName");
            String tableComment = matcher.group("tableComment");
            System.out.println(tableName + "\t\t" + tableComment);
            System.out.println("==========");
            String columnsSQL = matcher.group("columnsSQL");
            if (columnsSQL != null && columnsSQL.length() > 0){
                Matcher colMatcher = COL_PATTERN.matcher(columnsSQL);
                while (colMatcher.find()){
                    String fieldName = colMatcher.group("fieldName");
                    String fieldType = colMatcher.group("fieldType");
                    String fieldComment = colMatcher.group("fieldComment");
                    if (!"key".equalsIgnoreCase(fieldType)){
                        System.out.println(fieldName + "\t\t" + fieldType + "\t\t" + fieldComment);
                    }
                }
            }
        }
    }
    public static void main(String[] args){
        System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>");
        parse("CREATE TABLE `userinfo` (\n" +
                "  `user_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用戶ID',\n" +
                "  `username` varchar(255) NOT NULL COMMENT '用戶名',\n" +
                "  `addtime` datetime NOT NULL COMMENT '創建時間',\n" +
                "  PRIMARY KEY (`user_id`)\n" +
                ") ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用戶信息'");
        System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>");
        parse("CREATE TABLE `USER` (\n" +
                "`ID` varchar(32) PRIMARY KEY COMMENT '主鍵',\n" +
                "`password` varchar(32) NOT NULL COMMENT '密碼',\n" +
                "`username` varchar(32) NOT NULL COMMENT '用戶'\n" +
                ") ENGINE=InnoDB DEFAULT CHARSET=utf8;");
        System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>");
        parse("CREATE TABLE `tb_amount` (\n" +
                "`ID` int(10) NOT NULL AUTO_INCREMENT,\n" +
                "`PRODUCT_CODE` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '產品代碼',\n" +
                "`GENDER` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '性別(male,female)',\n" +
                "`MIN_INSURED_AGE` int(3) NULL DEFAULT NULL COMMENT '最小投保年齡',\n" +
                "`MAX_INSURED_AGE` int(3) NULL DEFAULT NULL COMMENT '最大投保年齡',\n" +
                "`AMOUNT` double(10, 2) NULL DEFAULT NULL COMMENT '基本保額',\n" +
                "`PREMIUM_RATE` double(10, 2) NULL DEFAULT NULL COMMENT '基本保費',\n" +
                "`YEAR_NUM` int(3) NULL DEFAULT NULL COMMENT '繳費年限',\n" +
                "`PREMIUM_TYPE` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '費率類型',\n" +
                "`INSURANCE_PERIOD` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '保險期間(30年,60年)',\n" +
                "`INSURANCE_PERIOD_TYPE` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '保險期間類型(如定期年0,定期歲1,終身2,以后終身對應值:200)',\n" +
                "`PAY_MODE` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '交費方式',\n" +
                "PRIMARY KEY (`ID`) USING BTREE\n" +
                ") ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;");
    }

控制臺輸出內容:

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
`userinfo`		用戶信息
==========
`user_id`		int		用戶ID
`username`		varchar		用戶名
`addtime`		datetime		創建時間
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
`USER`		null
==========
`ID`		varchar		主鍵
`password`		varchar		密碼
`username`		varchar		用戶
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
`tb_amount`		null
==========
`ID`		int		null
`PRODUCT_CODE`		varchar		產品代碼
`GENDER`		varchar		性別(male,female)
`MIN_INSURED_AGE`		int		最小投保年齡
`MAX_INSURED_AGE`		int		最大投保年齡
`AMOUNT`		double		基本保額
`PREMIUM_RATE`		double		基本保費
`YEAR_NUM`		int		繳費年限
`PREMIUM_TYPE`		varchar		費率類型
`INSURANCE_PERIOD`		varchar		保險期間(30年,60年)
`INSURANCE_PERIOD_TYPE`		varchar		保險期間類型(如定期年0,定期歲1,終身2,以后終身對應值:200)
`PAY_MODE`		varchar		交費方式

以上就是動力節點小編介紹的"Java正則表達式匹配字符串提取中間值"的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業老師隨時為您服務。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 手机看片国产精品 | 日本不卡不码高清免费观看 | 偷偷鲁国内视频视频在线 | 欧美日韩国产高清精卡 | 在线观看免费精品国产 | 免费观看h片 | 国内精品久久久久影院日本 | 国产福利在线免费观看 | 日本一区二区免费视频 | 在线精品一区二区三区 | 国产大学生一级毛片绿象 | 欧美操片| 中国一级毛片aaa片 中国一级毛片录像 | 日产精品一二三四区国产 | 欧美色插| 中文字幕在线精品视频万部 | 国产精品国产精品国产专区不卡 | 美国免费三片在线观看 | 91网站国产 | 中文字幕一区二区三区在线观看 | 国产一区二区精品久久凹凸 | 国产精品精品视频 | 麻豆成人精品国产免费 | 欧美一级视频精品观看 | 精品成人在线视频 | 草的我好爽的网站 | 99热久久这里只精品国产ww | 天天操狠狠 | 99尹人香蕉国产免费天天拍 | 91资源| 久久另类 | 天天舔天天爽 | 国产农村妇女毛片精品久久 | 欧美激情精品久久久久 | 99久久日本一区二区波多野结衣 | 久久青草免费91线频观看站街 | 成人国产亚洲 | 尹人香蕉网在线观看视频 | 日日摸日日碰夜夜爽久久 | 国产精品福利午夜h视频 | 狠狠激情五月综合婷婷俺 |