<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
有時候正規表示式不只是匹配一下什麼數位/郵箱/身份證/日期等等,還需要匹配某一段文字,並按照既定格式提取其中的某些值.
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\>
來自github網友@ydq 給SpringBootCodeGenerator貢獻的正規表示式,非常不錯,值得深刻學習.
//匹配整個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 + "tt" + 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 + "tt" + fieldType + "tt" + 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 BTREEn" + ") 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正規表示式匹配字串並提取中間值的文章就介紹到這了,更多相關Java正則匹配字串內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45