Repository: any86/any-rule Branch: master Commit: 43abe0f89526 Files: 39 Total size: 88.6 KB Directory structure: gitextract_h_p5umc3/ ├── .circleci/ │ └── config.yml ├── .gitattributes ├── .github/ │ └── workflows/ │ └── nodejs.yml ├── .gitignore ├── .vscodeignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── __test__/ │ └── rule.js ├── package.json ├── packages/ │ └── www/ │ ├── .gitignore │ ├── LICENSE │ ├── babel.config.js │ ├── package.json │ ├── prettier.config.js │ ├── public/ │ │ ├── index.html │ │ ├── manifest.json │ │ └── sw.js │ ├── scripts/ │ │ └── demo.js │ ├── src/ │ │ ├── App.vue │ │ ├── RULES.js │ │ └── main.js │ └── vue.config.js ├── scripts/ │ ├── genCommond.js │ └── md.js ├── src/ │ ├── extension.ts │ ├── insertLog.ts │ ├── interface.d.ts │ ├── shared.ts │ ├── showResultMessage.ts │ ├── test/ │ │ ├── runTest.ts │ │ └── suite/ │ │ ├── extension.test.ts │ │ └── index.ts │ ├── useCommand.ts │ ├── useMenuCommand.ts │ └── useQuickPick.ts ├── tsconfig.json ├── tslint.json └── webpack.config.js ================================================ FILE CONTENTS ================================================ ================================================ FILE: .circleci/config.yml ================================================ # Javascript Node CircleCI 2.0 configuration file # # Check https://circleci.com/docs/2.0/language-javascript/ for more details # version: 2 jobs: build: filters: branches: ignore: - gh-pages docker: # specify the version you desire here - image: circleci/node:12.14.1 # Specify service dependencies here if necessary # CircleCI maintains a library of pre-built images # documented at https://circleci.com/docs/2.0/circleci-images/ # - image: circleci/mongo:3.4.4 working_directory: ~/repo parallelism: 1 steps: - checkout # - restore_cache: # key: dependency-cache-{{ checksum "package.json" }} # - run: yarn install # - run: yarn add codecov - run: yarn add chalk@2.4.2 # - save_cache: # key: dependency-cache-{{ checksum "package.json" }} # paths: # - ./node_modules # run tests! - run: yarn test:rules # - run: ./node_modules/.bin/codecov ================================================ FILE: .gitattributes ================================================ packages/*/** linguist-vendored ================================================ FILE: .github/workflows/nodejs.yml ================================================ name: Node CI on: [push] jobs: test: runs-on: ubuntu-latest steps: - uses: actions/checkout@master - name: Use Node.js 10.x uses: actions/setup-node@v1 with: node-version: 10.x - name: test run: | npm i npm run test:rules ================================================ FILE: .gitignore ================================================ out node_modules coverage .nyc_output .vscode-test/ .idea .vscode .DS_Store *.vsix yarn-error.log .rpt2_cache dist ================================================ FILE: .vscodeignore ================================================ .vscode/** .vscode-test/** out/test/** src/** .gitignore vsc-extension-quickstart.md **/tsconfig.json **/tslint.json **/*.map **/*.ts **/node_modules ================================================ FILE: CHANGELOG.md ================================================ # 更新日志 🚀 [提交问题](https://github.com/any86/any-rule/issues/new) ### 0.3.18(2022-11-07) - 优化数字/货币金额(支持负数、千分位分隔符) - 优化小数(支持科学计数) - 优化缩短"用户名校验"正则长度 - 增加户口薄正则 - 增加军官证正则 - 修复MAC地址的第二位一定是偶数(#264) ### 0.3.13(2022-01-10) - 修正"网址"正则, 兼容更多符合的网址. - 修正澳门身份证错误. ### 0.3.12(2021-10-20) - 修复网址中带有"()"不能通过. - 新增"整数"/"浮点数"等正则. ### 0.3.11(2021-09-26) - 修复新版vscode中"@zz"字符失效. - 优化"身份证15/18"正则. ### 0.3.10(2021-05-28) - 禁止"日期"可以通过"00"月和"00"日 ### 0.3.9(2021-04-20) - 新增"GUID/UUID"正则. - 修复ip中的"."没有被转义. ### 0.3.8(2021-01-17) - 优化一些冗余的正则拼写 - 修复新能源汽车不匹配第三位为字母的情况. - 座机电话兼容带分机号的情况. ### 0.3.7(2020-11-25) - 修复"IPv4"不严格, 且增加端口校验. - 新增"座机电话(区号可选)" ### 0.3.6(2020-08-03) - 新增"港澳台身份证" ### 0.3.5(2020-07-18) - 修复"车牌号"可以通过"浙苏H6F681"的问题 - 新增"数字和英文字母组成,并且同时含有数字和英文字母" ### 0.3.4(2020-06-14) - 修正"车牌号(新能源+非新能源)"未对长度进行限制. - 修正"身份证"中月份可以匹配00月的bug. - 新增"匹配连续重复的字符"正则. - 修正座机支持4位区号,8位电话号. - 修正, 根据用户需求, "qq@qq"样式的email邮箱地址不再通过验证. ### 0.3.3(2020-04-28) - 优化增加"身份证中日期的约束". - 优化"html注释|座机|密码"等正则. - 新增"mac地址"正则. ### 0.3.2(2020-04-03) - 修复"linux文件夹"正则不能匹配"/". - 部分正则标题增加"英文关键字", 方便检索. ### 0.3.1 (2020-03-12) - 修复"@zz唤醒"和"菜单唤醒"在某些机型下失效的bug. - 修复"设置后未生效". - 修改部分提示图标. - 合并'linux文件'和'linux文件夹'正则. - 新增'linux隐藏文件'正则. ### 0.3.0 (2020-02-28) - 修改"zz."触发为"@zz"触发. - 增加右键唤醒正则菜单. ![](https://user-gold-cdn.xitu.io/2020/2/28/1708764046b38231?w=381&h=413&f=png&s=73047) ### 0.2.0 (2020-02-21) - 优化"zz."体验, 改用"quickPick"组件以支持"模糊搜索". ![gif](https://user-gold-cdn.xitu.io/2020/2/23/1706df78b18466fd?w=954&h=372&f=gif&s=1732199) - 增加"设置"功能, 可以在设置中搜索"any-rule". - 新增"🦕图解正则". ![](https://user-gold-cdn.xitu.io/2020/2/23/1706e32c3a6fb116?w=533&h=95&f=png&s=21563) ![](https://user-gold-cdn.xitu.io/2020/2/23/1706e349b600c28b?w=1151&h=500&f=png&s=45210) ### 0.1.0 - 新增支持在代码任意位置输入"zz."唤醒正则列表. ### 0.0.13 - 给"统一社会信用代码"增加^$标记 - 修复图片/视频连接匹配不严谨 - 增加"机身码IMEI"正则 - 增加"火车车次"正则 ### 0.0.12 - 增加"必须带端口号的网址(或ip)"正则 - 修复网址可以匹配"...."的错误 ### 0.0.11 - 增加"统一社会信用代码"正则 ### 0.0.10 - 迅雷正则增加thunderx规则的支持 ### 0.0.9 - 修复"ed2k"正则错误 ### 0.0.8 - 优化车牌号正则 ### 0.0.7 - 更新"银行卡"的匹配长度为10-30位,参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1) ### 0.0.6 - 修复"手机号(严禁)正则"错误. ### 0.0.5 - 增加正则"迅雷链接" / "ed2k连接" / "磁力链接" / "子网掩码" / "linux文件(夹)路径" / "window文件(夹)路径" ### 0.0.4 - 优化"大于0, 小于150, 支持小数位出现5"减少没必要的捕获 - 修复"html注释"没有匹配换行符 ### 0.0.3 - 解决vscode低版本兼容问题 - 替换主页的git图地址 ================================================ FILE: LICENSE ================================================ MIT License Copyright (c) 2021 Russell Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ================================================ FILE: README.md ================================================ # 正则大全 ![已收录84条](https://img.shields.io/badge/已收录-84条-673ab7.svg) [![版本](https://badgen.net/vs-marketplace/v/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule) [![安装量](https://badgen.net/vs-marketplace/i/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule) [![下载量](https://badgen.net/vs-marketplace/d/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule) ![MIT](https://img.shields.io/badge/license-MIT-F44336.svg) [![CircleCI](https://badgen.net/github/status/any86/any-rule/master/ci/circleci)](https://circleci.com/gh/any86/any-rule) 🦕支持**web** / **vscode** / **idea** / **Alfred Workflow**多平台 ## :rocket:web版本 https://any-rule.vercel.app/ ## 🍭vscode插件 ### 安装 vscode应用商店中搜索"**any-rule**". ### 使用 **方式1:** 1. 按**F1**(mac下fn+F1)打开正则列表. 2. **输入关键词搜索**, 比如"手机". ![GIF](https://user-images.githubusercontent.com/8264787/146724787-888a8666-5d2a-4e5e-b383-aec7c53bd312.gif) **方式2:** 右键选择"🦕正则大全". ![GIF](https://user-images.githubusercontent.com/8264787/146725447-4d92caed-2dd0-4f11-91d1-8da9cd8ff08b.gif) **方式3:** 在代码任意位置输入"**@zz**". ![GIF](https://user-images.githubusercontent.com/8264787/146725402-30b34119-b709-4d49-adb2-af8dbb786d3b.gif) ## 👩‍🏫图解正则
查看详情 每次在any-rule中选择正则后会弹出提示, 可点击"🤖图解正则". ![image](https://user-images.githubusercontent.com/8264787/146726200-d97e48c3-df76-4531-8210-b6935fffb997.png) 点击后可以看到正则解析, 方便大家学习. ![image](https://user-images.githubusercontent.com/8264787/146726350-58166bf9-7f7f-4685-86aa-f055d0c0b914.png) **注意**: 图解直接使用了https://regexper.com, 在此对作者表示敬意和感谢.
## 社区版本 社区版本非本人维护, 只是其他开发者使用了any-rule整理的正则内容, 如使用出现问题可直接与其开发者联系. [idea版](https://github.com/zhoriya/idea-rule) [Alfred Workflow版](https://github.com/cccyb/workflows) [hyjs: 函数封装版](https://github.com/heiyehk/hyjs/tree/main/packages/utils) [命令行版本](https://github.com/shenguanjiejie/workwork) [uTools版本](https://github.com/trentlee0/utools-any-rule) ## :fire:关于PR 欢迎大家PR, 步骤如下: 1. **正则**请在**packages/www/src/RULES.js**中添加. 2. 运行`npm run test:rules`进行测试. 3. 运行`npm run build:md`更新**README.md**. 4. 请务必提交到**develop**分支. 在此感谢大家对**any-rule**做出的贡献! ## 🍔正则 ### 火车车次 ```javascript /^[GCDZTSPKXLY1-9]\d{1,4}$/ ``` ### 手机机身码(IMEI) ```javascript /^\d{15,17}$/ ``` ### 必须带端口号的网址(或ip) ```javascript /^((ht|f)tps?:\/\/)?[\w-]+(\.[\w-]+)+:\d{1,5}\/?$/ ``` ### 网址(URL) ```javascript /^(((ht|f)tps?):\/\/)?([^!@#$%^&*?.\s-]([^!@#$%^&*?.\s]{0,63}[^!@#$%^&*?.\s])?\.)+[a-z]{2,6}\/?/ ``` ### 统一社会信用代码 ```javascript /^[0-9A-HJ-NPQRTUWXY]{2}\d{6}[0-9A-HJ-NPQRTUWXY]{10}$/ ``` ### 统一社会信用代码(宽松匹配)(15位/18位/20位数字/字母) ```javascript /^(([0-9A-Za-z]{15})|([0-9A-Za-z]{18})|([0-9A-Za-z]{20}))$/ ``` ### 迅雷链接 ```javascript /^thunderx?:\/\/[a-zA-Z\d]+=$/ ``` ### ed2k链接(宽松匹配) ```javascript /^ed2k:\/\/\|file\|.+\|\/$/ ``` ### 磁力链接(宽松匹配) ```javascript /^magnet:\?xt=urn:btih:[0-9a-fA-F]{40,}.*$/ ``` ### 子网掩码(不包含 0.0.0.0) ```javascript /^(254|252|248|240|224|192|128)\.0\.0\.0|255\.(254|252|248|240|224|192|128|0)\.0\.0|255\.255\.(254|252|248|240|224|192|128|0)\.0|255\.255\.255\.(255|254|252|248|240|224|192|128|0)$/ ``` ### linux"隐藏文件"路径 ```javascript /^\/(?:[^/]+\/)*\.[^/]*/ ``` ### linux文件夹路径 ```javascript /^\/(?:[^/]+\/)*$/ ``` ### linux文件路径 ```javascript /^\/(?:[^/]+\/)*[^/]+$/ ``` ### window"文件夹"路径 ```javascript /^[a-zA-Z]:\\(?:\w+\\?)*$/ ``` ### window下"文件"路径 ```javascript /^[a-zA-Z]:\\(?:\w+\\)*\w+\.\w+$/ ``` ### 股票代码(A股) ```javascript /^(s[hz]|S[HZ])(000[\d]{3}|002[\d]{3}|300[\d]{3}|600[\d]{3}|60[\d]{4})$/ ``` ### 大于等于0, 小于等于150, 支持小数位出现5, 如145.5, 用于判断考卷分数 ```javascript /^150$|^(?:\d|[1-9]\d|1[0-4]\d)(?:\.5)?$/ ``` ### html注释 ```javascript //g ``` ### md5格式(32位) ```javascript /^[a-fA-F0-9]{32}$/ ``` ### GUID/UUID ```javascript /^[a-f\d]{4}(?:[a-f\d]{4}-){4}[a-f\d]{12}$/i ``` ### 版本号(version)格式必须为X.Y.Z ```javascript /^\d+(?:\.\d+){2}$/ ``` ### 视频(video)链接地址(视频格式可按需增删) ```javascript /^https?:\/\/(.+\/)+.+(\.(swf|avi|flv|mpg|rm|mov|wav|asf|3gp|mkv|rmvb|mp4))$/i ``` ### 图片(image)链接地址(图片格式可按需增删) ```javascript /^https?:\/\/(.+\/)+.+(\.(gif|png|jpg|jpeg|webp|svg|psd|bmp|tif))$/i ``` ### 24小时制时间(HH:mm:ss) ```javascript /^(?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/ ``` ### 12小时制时间(hh:mm:ss) ```javascript /^(?:1[0-2]|0?[1-9]):[0-5]\d:[0-5]\d$/ ``` ### base64格式 ```javascript /^\s*data:(?:[a-z]+\/[a-z0-9-+.]+(?:;[a-z-]+=[a-z0-9-]+)?)?(?:;base64)?,([a-z0-9!$&',()*+;=\-._~:@/?%\s]*?)\s*$/i ``` ### 数字/货币金额(支持负数、千分位分隔符) ```javascript /^-?\d{1,3}(,\d{3})*(\.\d{1,2})?$/ ``` ### 银行卡号(10到30位, 覆盖对公/私账户, 参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1)) ```javascript /^[1-9]\d{9,29}$/ ``` ### 中文姓名 ```javascript /^(?:[\u4e00-\u9fa5·]{2,16})$/ ``` ### 英文姓名 ```javascript /(^[a-zA-Z][a-zA-Z\s]{0,20}[a-zA-Z]$)/ ``` ### 车牌号(新能源) ```javascript /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z](([DF]((?![IO])[a-zA-Z0-9](?![IO]))[0-9]{4})|([0-9]{5}[DF]))$/ ``` ### 车牌号(非新能源) ```javascript /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]$/ ``` ### 车牌号(新能源+非新能源) ```javascript /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4,5}[A-HJ-NP-Z0-9挂学警港澳]$/ ``` ### 手机号(mobile phone)中国(严谨), 根据工信部2019年最新公布的手机号段 ```javascript /^(?:(?:\+|00)86)?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[01256789]))\d{8}$/ ``` ### 手机号(mobile phone)中国(宽松), 只要是13,14,15,16,17,18,19开头即可 ```javascript /^(?:(?:\+|00)86)?1[3-9]\d{9}$/ ``` ### 手机号(mobile phone)中国(最宽松), 只要是1开头即可, 如果你的手机号是用来接收短信, 优先建议选择这一条 ```javascript /^(?:(?:\+|00)86)?1\d{10}$/ ``` ### 日期(宽松) ```javascript /^\d{1,4}(-)(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31)$/ ``` ### 日期(严谨, 支持闰年判断) ```javascript /^(([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29)$/ ``` ### 中国省 ```javascript /^浙江|上海|北京|天津|重庆|黑龙江|吉林|辽宁|内蒙古|河北|新疆|甘肃|青海|陕西|宁夏|河南|山东|山西|安徽|湖北|湖南|江苏|四川|贵州|云南|广西|西藏|江西|广东|福建|台湾|海南|香港|澳门$/ ``` ### 可以被moment转化成功的时间 YYYYMMDD HH:mm:ss ```javascript /^\d{4}([/:-\S])(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31) (?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/ ``` ### email(邮箱) ```javascript /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/ ``` ### 座机(tel phone)电话(国内),如: 0341-86091234 ```javascript /^(?:(?:\d{3}-)?\d{8}|^(?:\d{4}-)?\d{7,8})(?:-\d+)?$/ ``` ### 身份证号(1代,15位数字) ```javascript /^[1-9]\d{7}(?:0\d|10|11|12)(?:0[1-9]|[1-2][\d]|30|31)\d{3}$/ ``` ### 身份证号(2代,18位数字),最后一位是校验位,可能为数字或字符X ```javascript /^[1-9]\d{5}(?:18|19|20)\d{2}(?:0[1-9]|10|11|12)(?:0[1-9]|[1-2]\d|30|31)\d{3}[\dXx]$/ ``` ### 身份证号, 支持1/2代(15位/18位数字) ```javascript /^\d{6}((((((19|20)\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|(((19|20)\d{2})(0[13578]|1[02])31)|((19|20)\d{2})02(0[1-9]|1\d|2[0-8])|((((19|20)([13579][26]|[2468][048]|0[48]))|(2000))0229))\d{3})|((((\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|((\d{2})(0[13578]|1[02])31)|((\d{2})02(0[1-9]|1\d|2[0-8]))|(([13579][26]|[2468][048]|0[048])0229))\d{2}))(\d|X|x)$/ ``` ### 护照(包含香港、澳门) ```javascript /(^[EeKkGgDdSsPpHh]\d{8}$)|(^(([Ee][a-fA-F])|([DdSsPp][Ee])|([Kk][Jj])|([Mm][Aa])|(1[45]))\d{7}$)/ ``` ### 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线组合 ```javascript /^[a-zA-Z]\w{4,15}$/ ``` ### 中文/汉字 ```javascript /^(?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])+$/ ``` ### 小数(支持科学计数) ```javascript /^[+-]?(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)$/ ``` ### 只包含数字 ```javascript /^\d+$/ ``` ### html标签(宽松匹配) ```javascript /<(\w+)[^>]*>(.*?<\/\1>)?/ ``` ### 匹配中文汉字和中文标点 ```javascript /[\u4e00-\u9fa5|\u3002|\uff1f|\uff01|\uff0c|\u3001|\uff1b|\uff1a|\u201c|\u201d|\u2018|\u2019|\uff08|\uff09|\u300a|\u300b|\u3008|\u3009|\u3010|\u3011|\u300e|\u300f|\u300c|\u300d|\ufe43|\ufe44|\u3014|\u3015|\u2026|\u2014|\uff5e|\ufe4f|\uffe5]/ ``` ### qq号格式正确 ```javascript /^[1-9][0-9]{4,10}$/ ``` ### 数字和字母组成 ```javascript /^[A-Za-z0-9]+$/ ``` ### 英文字母 ```javascript /^[a-zA-Z]+$/ ``` ### 小写英文字母组成 ```javascript /^[a-z]+$/ ``` ### 大写英文字母 ```javascript /^[A-Z]+$/ ``` ### 密码强度校验,最少6位,包括至少1个大写字母,1个小写字母,1个数字,1个特殊字符 ```javascript /^\S*(?=\S{6,})(?=\S*\d)(?=\S*[A-Z])(?=\S*[a-z])(?=\S*[!@#$%^&*? ])\S*$/ ``` ### 用户名校验,4到16位(字母,数字,下划线,减号) ```javascript /^[\w-]{4,16}$/ ``` ### ip-v4[:端口] ```javascript /^((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.){3}(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])(?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$/ ``` ### ip-v6[:端口] ```javascript /(^(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))$)|(^\[(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))\](?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$)/i ``` ### 16进制颜色 ```javascript /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}|[a-fA-F0-9]{8}|[a-fA-F0-9]{4})$/ ``` ### 微信号(wx),6至20位,以字母开头,字母,数字,减号,下划线 ```javascript /^[a-zA-Z][-_a-zA-Z0-9]{5,19}$/ ``` ### 邮政编码(中国) ```javascript /^(0[1-7]|1[0-356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[0-5]|8[013-6])\d{4}$/ ``` ### 中文和数字 ```javascript /^((?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])|(\d))+$/ ``` ### 不能包含字母 ```javascript /^[^A-Za-z]*$/ ``` ### java包名 ```javascript /^([a-zA-Z_]\w*)+([.][a-zA-Z_]\w*)+$/ ``` ### mac地址 ```javascript /^(([a-f0-9][0,2,4,6,8,a,c,e]:([a-f0-9]{2}:){4})|([a-f0-9][0,2,4,6,8,a,c,e]-([a-f0-9]{2}-){4}))[a-f0-9]{2}$/i ``` ### 匹配连续重复的字符 ```javascript /(.)\1+/ ``` ### 数字和英文字母组成,并且同时含有数字和英文字母 ```javascript /^(?=.*[a-zA-Z])(?=.*\d).+$/ ``` ### 香港身份证 ```javascript /^[a-zA-Z]\d{6}\([\dA]\)$/ ``` ### 澳门身份证 ```javascript /^[1|5|7]\d{6}\(\d\)$/ ``` ### 台湾身份证 ```javascript /^[a-zA-Z][0-9]{9}$/ ``` ### 大写字母,小写字母,数字,特殊符号 `@#$%^&*`~()-+=` 中任意3项密码 ```javascript /^(?![a-zA-Z]+$)(?![A-Z0-9]+$)(?![A-Z\W_!@#$%^&*`~()-+=]+$)(?![a-z0-9]+$)(?![a-z\W_!@#$%^&*`~()-+=]+$)(?![0-9\W_!@#$%^&*`~()-+=]+$)[a-zA-Z0-9\W_!@#$%^&*`~()-+=]/ ``` ### ASCII码表中的全部的特殊字符 ```javascript /[\x21-\x2F\x3A-\x40\x5B-\x60\x7B-\x7E]+/ ``` ### 正整数,不包含0 ```javascript /^\+?[1-9]\d*$/ ``` ### 负整数,不包含0 ```javascript /^-[1-9]\d*$/ ``` ### 整数 ```javascript /^(?:0|(?:-?[1-9]\d*))$/ ``` ### 浮点数 ```javascript /^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9]\d*|0\.0+)$/ ``` ### 浮点数(严格) ```javascript /^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9])$/ ``` ### email(支持中文邮箱) ```javascript /^[A-Za-z0-9\u4e00-\u9fa5]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/ ``` ### 域名(非网址, 不包含协议) ```javascript /^([0-9a-zA-Z-]{1,}\.)+([a-zA-Z]{2,})$/ ``` ### 军官/士兵证 ```javascript /^[\u4E00-\u9FA5](字第)([0-9a-zA-Z]{4,8})(号?)$/ ``` ### 户口薄 ```javascript /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/ ``` ================================================ FILE: __test__/rule.js ================================================ const chalk = require('chalk'); const RULES = require('../packages/www/src/RULES'); let failGroup = []; RULES.forEach(RULE => { testOne(RULE); }); function testOne(one) { const { rule, examples, title, counterExamples } = one; examples.forEach(example => { const isSuccess = rule.test(example); if (isSuccess) { console.log(chalk.green(`成功: ${title}, 用例: ${example}`)); } else { failGroup.push({title, example, is:'正例'}); console.log(chalk.red(`失败: ${title}, 用例: ${example}`)); } }) if (counterExamples) { counterExamples.forEach(example => { const isFail = !rule.test(example); if (isFail) { console.log(chalk.green(`反例成功(counterExamples): ${title}`)); } else { failGroup.push({title, example, is: '反例'}); console.log(chalk.red(`反例失败(counterExamples): ${title}, 用例: ${example}`)); } }); } } if(0 === failGroup.length) { console.log(chalk.green('\r\n🚀 全部测试通过!')) } else { console.log(chalk.red('='.repeat(30) + '🔥 未通过测试' + '='.repeat(30))); // 失败列表 failGroup.forEach(item=>{ const str = `${item.title}[${item.is}]: ${item.example}`; console.log(chalk.red(str)); }); } ================================================ FILE: package.json ================================================ { "name": "any-rule", "publisher": "russell", "displayName": "any-rule", "description": "你要的\"正则\"都在这!", "version": "0.3.18", "keywords": [ "vscode", "typescript", "regxp", "正则" ], "husky": { "hooks": { "pre-push": "npm run test:rules" } }, "scripts": { "build:md": "node ./scripts/md.js", "build": "npm run test:rules && npm version patch && node ./scripts/genCommond.js && vsce package --yarn && npm run build:md", "vscode:prepublish": "npm run compile", "compile": "webpack --mode production", "watch": "tsc -watch -p ./", "pretest": "npm run compile", "test": "node ./out/test/runTest.js", "test:rules": "node __test__/rule", "release:demo": "cd packages/www && yarn release", "dev:demo": "cd packages/www && yarn serve" }, "engines": { "vscode": "^1.12.0" }, "categories": [ "Snippets", "Other" ], "icon": "images/vscode-logo.png", "bugs": { "url": "https://github.com/any86/any-rule/issues" }, "repository": { "type": "git", "url": "https://github.com/any86/any-rule.git" }, "activationEvents": [ "*" ], "main": "./out/extension.js", "contributes": { "configuration": { "type": "object", "title": "any-rule", "properties": { "any-rule.triggerString": { "type": "string", "default": "@zz", "description": "触发字符串" }, "any-rule.supportedLanguages": { "type": "string", "default": "*,javascript,javascriptreact,typescript,typescriptreact,vue,vue-postcss,vue-sugarss,vue-html,json,jsonc,graphql,dart,sql,go,java,php,jade,python,swift,markdown", "description": "支持的开发语言(用','分割)" } } }, "menus": { "editor/context": [ { "when": "editorFocus", "command": "extension.rule.callByMenu", "group": "navigation" } ] }, "commands": [ { "command": "extension.rule0", "title": "$(rocket) zz: 火车车次" }, { "command": "extension.rule1", "title": "$(rocket) zz: 手机机身码(IMEI)" }, { "command": "extension.rule2", "title": "$(rocket) zz: 必须带端口号的网址(或ip)" }, { "command": "extension.rule3", "title": "$(rocket) zz: 网址(URL)" }, { "command": "extension.rule4", "title": "$(rocket) zz: 统一社会信用代码" }, { "command": "extension.rule5", "title": "$(rocket) zz: 统一社会信用代码(宽松匹配)(15位/18位/20位数字/字母)" }, { "command": "extension.rule6", "title": "$(rocket) zz: 迅雷链接" }, { "command": "extension.rule7", "title": "$(rocket) zz: ed2k链接(宽松匹配)" }, { "command": "extension.rule8", "title": "$(rocket) zz: 磁力链接(宽松匹配)" }, { "command": "extension.rule9", "title": "$(rocket) zz: 子网掩码(不包含 0.0.0.0)" }, { "command": "extension.rule10", "title": "$(rocket) zz: linux\"隐藏文件\"路径" }, { "command": "extension.rule11", "title": "$(rocket) zz: linux文件夹路径" }, { "command": "extension.rule12", "title": "$(rocket) zz: linux文件路径" }, { "command": "extension.rule13", "title": "$(rocket) zz: window\"文件夹\"路径" }, { "command": "extension.rule14", "title": "$(rocket) zz: window下\"文件\"路径" }, { "command": "extension.rule15", "title": "$(rocket) zz: 股票代码(A股)" }, { "command": "extension.rule16", "title": "$(rocket) zz: 大于等于0, 小于等于150, 支持小数位出现5, 如145.5, 用于判断考卷分数" }, { "command": "extension.rule17", "title": "$(rocket) zz: html注释" }, { "command": "extension.rule18", "title": "$(rocket) zz: md5格式(32位)" }, { "command": "extension.rule19", "title": "$(rocket) zz: GUID/UUID" }, { "command": "extension.rule20", "title": "$(rocket) zz: 版本号(version)格式必须为X.Y.Z" }, { "command": "extension.rule21", "title": "$(rocket) zz: 视频(video)链接地址(视频格式可按需增删)" }, { "command": "extension.rule22", "title": "$(rocket) zz: 图片(image)链接地址(图片格式可按需增删)" }, { "command": "extension.rule23", "title": "$(rocket) zz: 24小时制时间(HH:mm:ss)" }, { "command": "extension.rule24", "title": "$(rocket) zz: 12小时制时间(hh:mm:ss)" }, { "command": "extension.rule25", "title": "$(rocket) zz: base64格式" }, { "command": "extension.rule26", "title": "$(rocket) zz: 数字/货币金额(支持负数、千分位分隔符)" }, { "command": "extension.rule27", "title": "$(rocket) zz: 银行卡号(10到30位, 覆盖对公/私账户, 参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1))" }, { "command": "extension.rule28", "title": "$(rocket) zz: 中文姓名" }, { "command": "extension.rule29", "title": "$(rocket) zz: 英文姓名" }, { "command": "extension.rule30", "title": "$(rocket) zz: 车牌号(新能源)" }, { "command": "extension.rule31", "title": "$(rocket) zz: 车牌号(非新能源)" }, { "command": "extension.rule32", "title": "$(rocket) zz: 车牌号(新能源+非新能源)" }, { "command": "extension.rule33", "title": "$(rocket) zz: 手机号(mobile phone)中国(严谨), 根据工信部2019年最新公布的手机号段" }, { "command": "extension.rule34", "title": "$(rocket) zz: 手机号(mobile phone)中国(宽松), 只要是13,14,15,16,17,18,19开头即可" }, { "command": "extension.rule35", "title": "$(rocket) zz: 手机号(mobile phone)中国(最宽松), 只要是1开头即可, 如果你的手机号是用来接收短信, 优先建议选择这一条" }, { "command": "extension.rule36", "title": "$(rocket) zz: 日期(宽松)" }, { "command": "extension.rule37", "title": "$(rocket) zz: 日期(严谨, 支持闰年判断)" }, { "command": "extension.rule38", "title": "$(rocket) zz: 中国省" }, { "command": "extension.rule39", "title": "$(rocket) zz: 可以被moment转化成功的时间 YYYYMMDD HH:mm:ss" }, { "command": "extension.rule40", "title": "$(rocket) zz: email(邮箱)" }, { "command": "extension.rule41", "title": "$(rocket) zz: 座机(tel phone)电话(国内),如: 0341-86091234" }, { "command": "extension.rule42", "title": "$(rocket) zz: 身份证号(1代,15位数字)" }, { "command": "extension.rule43", "title": "$(rocket) zz: 身份证号(2代,18位数字),最后一位是校验位,可能为数字或字符X" }, { "command": "extension.rule44", "title": "$(rocket) zz: 身份证号, 支持1/2代(15位/18位数字)" }, { "command": "extension.rule45", "title": "$(rocket) zz: 护照(包含香港、澳门)" }, { "command": "extension.rule46", "title": "$(rocket) zz: 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线组合" }, { "command": "extension.rule47", "title": "$(rocket) zz: 中文/汉字" }, { "command": "extension.rule48", "title": "$(rocket) zz: 小数(支持科学计数)" }, { "command": "extension.rule49", "title": "$(rocket) zz: 只包含数字" }, { "command": "extension.rule50", "title": "$(rocket) zz: html标签(宽松匹配)" }, { "command": "extension.rule51", "title": "$(rocket) zz: 匹配中文汉字和中文标点" }, { "command": "extension.rule52", "title": "$(rocket) zz: qq号格式正确" }, { "command": "extension.rule53", "title": "$(rocket) zz: 数字和字母组成" }, { "command": "extension.rule54", "title": "$(rocket) zz: 英文字母" }, { "command": "extension.rule55", "title": "$(rocket) zz: 小写英文字母组成" }, { "command": "extension.rule56", "title": "$(rocket) zz: 大写英文字母" }, { "command": "extension.rule57", "title": "$(rocket) zz: 密码强度校验,最少6位,包括至少1个大写字母,1个小写字母,1个数字,1个特殊字符" }, { "command": "extension.rule58", "title": "$(rocket) zz: 用户名校验,4到16位(字母,数字,下划线,减号)" }, { "command": "extension.rule59", "title": "$(rocket) zz: ip-v4[:端口]" }, { "command": "extension.rule60", "title": "$(rocket) zz: ip-v6[:端口]" }, { "command": "extension.rule61", "title": "$(rocket) zz: 16进制颜色" }, { "command": "extension.rule62", "title": "$(rocket) zz: 微信号(wx),6至20位,以字母开头,字母,数字,减号,下划线" }, { "command": "extension.rule63", "title": "$(rocket) zz: 邮政编码(中国)" }, { "command": "extension.rule64", "title": "$(rocket) zz: 中文和数字" }, { "command": "extension.rule65", "title": "$(rocket) zz: 不能包含字母" }, { "command": "extension.rule66", "title": "$(rocket) zz: java包名" }, { "command": "extension.rule67", "title": "$(rocket) zz: mac地址" }, { "command": "extension.rule68", "title": "$(rocket) zz: 匹配连续重复的字符" }, { "command": "extension.rule69", "title": "$(rocket) zz: 数字和英文字母组成,并且同时含有数字和英文字母" }, { "command": "extension.rule70", "title": "$(rocket) zz: 香港身份证 " }, { "command": "extension.rule71", "title": "$(rocket) zz: 澳门身份证 " }, { "command": "extension.rule72", "title": "$(rocket) zz: 台湾身份证 " }, { "command": "extension.rule73", "title": "$(rocket) zz: 大写字母,小写字母,数字,特殊符号 `@#$%^&*`~()-+=` 中任意3项密码" }, { "command": "extension.rule74", "title": "$(rocket) zz: ASCII码表中的全部的特殊字符" }, { "command": "extension.rule75", "title": "$(rocket) zz: 正整数,不包含0" }, { "command": "extension.rule76", "title": "$(rocket) zz: 负整数,不包含0" }, { "command": "extension.rule77", "title": "$(rocket) zz: 整数" }, { "command": "extension.rule78", "title": "$(rocket) zz: 浮点数" }, { "command": "extension.rule79", "title": "$(rocket) zz: 浮点数(严格)" }, { "command": "extension.rule80", "title": "$(rocket) zz: email(支持中文邮箱)" }, { "command": "extension.rule81", "title": "$(rocket) zz: 域名(非网址, 不包含协议)" }, { "command": "extension.rule82", "title": "$(rocket) zz: 军官/士兵证" }, { "command": "extension.rule83", "title": "$(rocket) zz: 户口薄" }, { "command": "extension.rule.callByMenu", "title": "🦕正则大全(84条)" } ] }, "devDependencies": { "@types/glob": "^7.1.1", "@types/mocha": "^5.2.6", "@types/node": "^10.12.21", "@types/vscode": "^1.12.0", "glob": "^7.1.4", "husky": "^4.2.5", "mocha": "^6.1.4", "qiniu-js": "^2.5.5", "ts-loader": "^6.2.1", "tslint": "^5.12.1", "typescript": "^3.3.1", "vsce": "^1.74.0", "vscode-test": "^1.0.2", "webpack": "^4.41.6", "webpack-cli": "^3.3.11" }, "dependencies": { "axios": "^0.19.2", "transliteration": "^2.1.8" } } ================================================ FILE: packages/www/.gitignore ================================================ .DS_Store node_modules /dist # local env files .env.local .env.*.local # Log files npm-debug.log* yarn-debug.log* yarn-error.log* # Editor directories and files .idea .vscode *.suo *.ntvs* *.njsproj *.sln *.sw? ================================================ FILE: packages/www/LICENSE ================================================ MIT License Copyright (c) 2019 any86 Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ================================================ FILE: packages/www/babel.config.js ================================================ module.exports = { presets: [ '@vue/app' ] } ================================================ FILE: packages/www/package.json ================================================ { "name": "any-rule", "version": "0.1.0", "private": true, "scripts": { "serve": "vue-cli-service serve", "build": "vue-cli-service build", "release": "npm run build && node ./scripts/demo", "lint": "vue-cli-service lint", "rm:nm":"rimraf node_modules" }, "dependencies": { "clipboard": "^2.0.4", "core-js": "^2.6.5", "crypto-js": "^4.0.0", "lodash": "^4.17.13", "node-sass": "^6.0.0", "sass-loader": "^10.0.0", "vue": "^2.6.10" }, "devDependencies": { "@vue/cli-plugin-babel": "^3.8.0", "@vue/cli-plugin-eslint": "^3.8.0", "@vue/cli-service": "^3.8.0", "chalk": "^2.4.2", "gh-pages": "^2.0.1", "shelljs": "^0.8.3", "vue-template-compiler": "^2.6.10" }, "eslintConfig": { "root": true, "env": { "node": true }, "extends": [ "plugin:vue/essential", "eslint:recommended" ], "rules": {}, "parserOptions": { "parser": "babel-eslint" } }, "postcss": { "plugins": { "autoprefixer": {} } }, "browserslist": [ "> 1%", "last 2 versions" ] } ================================================ FILE: packages/www/prettier.config.js ================================================ // prettier.config.js or .prettierrc.js module.exports = { tabWidth: 4, semi: true, singleQuote: true, arrowParens: 'always', printWidth: 120 }; ================================================ FILE: packages/www/public/index.html ================================================ 正则大全
================================================ FILE: packages/www/public/manifest.json ================================================ { "short_name": "any-rule", "name": "正则大全", "icons": [ { "src": "/any-rule/icon.png", "type": "image/png", "sizes": "192x192" } ], "background_color": "#2196F3", "theme_color": "#2196F3", "display": "standalone", "start_url": "/any-rule" } ================================================ FILE: packages/www/public/sw.js ================================================ ================================================ FILE: packages/www/scripts/demo.js ================================================ var ghpages = require('gh-pages'); const shell = require('shelljs'); const chalk = require('chalk'); // 发布 ghpages.publish('./dist', { branch: 'gh-pages', }, (err) => { if(err) { console.log(chalk.red(err)); } else { shell.rm('-rf', './dist'); console.log(chalk.green('demo同步完成!')); } }); ================================================ FILE: packages/www/src/App.vue ================================================ ================================================ FILE: packages/www/src/RULES.js ================================================ module.exports = [{ title: '火车车次', rule: /^[GCDZTSPKXLY1-9]\d{1,4}$/, examples: ['G1868', 'D102', 'D9', 'Z5', 'Z24', 'Z17'] }, { title: '手机机身码(IMEI)', rule: /^\d{15,17}$/, examples: ['123456789012345', '1234567890123456', '12345678901234567'] }, { title: '必须带端口号的网址(或ip)', rule: /^((ht|f)tps?:\/\/)?[\w-]+(\.[\w-]+)+:\d{1,5}\/?$/, examples: ['https://www.qq.com:8080', '127.0.0.1:5050', 'baidu.com:8001', 'http://192.168.1.1:9090'], counterExamples: ['192.168.1.1', 'https://www.jd.com'] }, { // 参考: // https://baike.baidu.com/item/%E9%A1%B6%E7%BA%A7%E5%9F%9F%E5%90%8D#4_1 // https://baike.baidu.com/item/%E9%A1%B6%E7%BA%A7%E5%9F%9F%E5%90%8D#7 // 也参考谷歌浏览器的地址栏, 如果输入非字母不会被识别为域名 title: '网址(URL)', rule: /^(((ht|f)tps?):\/\/)?([^!@#$%^&*?.\s-]([^!@#$%^&*?.\s]{0,63}[^!@#$%^&*?.\s])?\.)+[a-z]{2,6}\/?/, examples: ['www.qq.com', 'https://vuejs.org/v2/api/#v-model', 'www.qq.99', '//www.qq.com', 'www.腾讯.cs', 'ftp://baidu.qq', 'http://baidu.com', 'https://www.amap.com/search?id=BV10060895&city=420111&geoobj=113.207951%7C29.992557%7C115.785782%7C31.204369&query_type=IDQ&query=%E5%85%89%E8%B0%B7%E5%B9%BF%E5%9C%BA(%E5%9C%B0%E9%93%81%E7%AB%99)&zoom=10.15', '360.com:8080/vue/#/a=1&b=2'], counterExamples: ['....'] }, { title: '统一社会信用代码', rule: /^[0-9A-HJ-NPQRTUWXY]{2}\d{6}[0-9A-HJ-NPQRTUWXY]{10}$/, examples: ['91230184MA1BUFLT44', '92371000MA3MXH0E3W'], }, { title: '统一社会信用代码(宽松匹配)(15位/18位/20位数字/字母)', rule: /^(([0-9A-Za-z]{15})|([0-9A-Za-z]{18})|([0-9A-Za-z]{20}))$/, examples: ['91110108772551611J', '911101085923662400'] }, { title: '迅雷链接', rule: /^thunderx?:\/\/[a-zA-Z\d]+=$/, examples: ['thunder://QUEsICdtYWduZXQ6P3h0PXVybjpidGloOjBCQTE0RTUxRkUwNjU1RjE0Qzc4NjE4RjY4NDY0QjZFNTEyNjcyOUMnWlo='], }, { title: 'ed2k链接(宽松匹配)', rule: /^ed2k:\/\/\|file\|.+\|\/$/, examples: ['ed2k://|file|%E5%AF%84%E7%94%9F%E8%99%AB.PARASITE.2019.HD-1080p.X264.AAC-UUMp4(ED2000.COM).mp4|2501554832|C0B93E0879C6071CBED732C20CE577A3|h=5HTKZPQFYRKORN52I3M7GQ4QQCIHFIBV|/'], }, { title: '磁力链接(宽松匹配)', rule: /^magnet:\?xt=urn:btih:[0-9a-fA-F]{40,}.*$/, examples: ['magnet:?xt=urn:btih:40A89A6F4FB1498A98087109D012A9A851FBE0FC'], }, { title: '子网掩码(不包含 0.0.0.0)', rule: /^(254|252|248|240|224|192|128)\.0\.0\.0|255\.(254|252|248|240|224|192|128|0)\.0\.0|255\.255\.(254|252|248|240|224|192|128|0)\.0|255\.255\.255\.(255|254|252|248|240|224|192|128|0)$/, examples: ['255.255.255.0', '255.255.255.255', '255.240.0.0'] }, { title: 'linux"隐藏文件"路径', rule: /^\/(?:[^/]+\/)*\.[^/]*/, examples: ['/usr/ad/.dd', '/root/.gitignore', '/.gitignore'] }, { title: 'linux文件夹路径', rule: /^\/(?:[^/]+\/)*$/, examples: ['/usr/ad/dd/', '/', '/root/', '/ a a / a / a a /'] }, { title: 'linux文件路径', rule: /^\/(?:[^/]+\/)*[^/]+$/, examples: ['/root/b.ts', '/root/abc'] }, { title: 'window"文件夹"路径', rule: /^[a-zA-Z]:\\(?:\w+\\?)*$/, examples: ['C:\\Users\\Administrator\\Desktop', 'e:\\m\\'] }, { title: 'window下"文件"路径', rule: /^[a-zA-Z]:\\(?:\w+\\)*\w+\.\w+$/, examples: ['C:\\Users\\Administrator\\Desktop\\qq.link', 'e:\\m\\vscode.exe'] }, { title: '股票代码(A股)', rule: /^(s[hz]|S[HZ])(000[\d]{3}|002[\d]{3}|300[\d]{3}|600[\d]{3}|60[\d]{4})$/, examples: ['sz000858', 'SZ002136', 'sz300675', 'SH600600', 'sh601155'] }, { title: '大于等于0, 小于等于150, 支持小数位出现5, 如145.5, 用于判断考卷分数', rule: /^150$|^(?:\d|[1-9]\d|1[0-4]\d)(?:\.5)?$/, examples: [150, 100.5] }, { title: 'html注释', rule: //g, examples: ['
chenguzhen87
-->'] }, { title: 'md5格式(32位)', rule: /^[a-fA-F0-9]{32}$/, examples: ['21fe181c5bfc16306a6828c1f7b762e8'], }, { title: 'GUID/UUID', rule: /^[a-f\d]{4}(?:[a-f\d]{4}-){4}[a-f\d]{12}$/i, examples: ['e155518c-ca1b-443c-9be9-fe90fdab7345', '41E3DAF5-6E37-4BCC-9F8E-0D9521E2AA8D', '00000000-0000-0000-0000-000000000000'], }, { title: '版本号(version)格式必须为X.Y.Z', rule: /^\d+(?:\.\d+){2}$/, examples: ['16.3.10'] }, { title: '视频(video)链接地址(视频格式可按需增删)', rule: /^https?:\/\/(.+\/)+.+(\.(swf|avi|flv|mpg|rm|mov|wav|asf|3gp|mkv|rmvb|mp4))$/i, examples: ['http://www.abc.com/video/wc.avi'] }, { title: '图片(image)链接地址(图片格式可按需增删)', rule: /^https?:\/\/(.+\/)+.+(\.(gif|png|jpg|jpeg|webp|svg|psd|bmp|tif))$/i, examples: ['https://www.abc.com/logo.png', 'http://www.abc.com/logo.png'] }, { title: '24小时制时间(HH:mm:ss)', rule: /^(?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/, examples: ['23:34:55'] }, { title: '12小时制时间(hh:mm:ss)', rule: /^(?:1[0-2]|0?[1-9]):[0-5]\d:[0-5]\d$/, examples: ['11:34:55'], counterExamples: ['23:34:55'] }, { title: 'base64格式', rule: /^\s*data:(?:[a-z]+\/[a-z0-9-+.]+(?:;[a-z-]+=[a-z0-9-]+)?)?(?:;base64)?,([a-z0-9!$&',()*+;=\-._~:@/?%\s]*?)\s*$/i, examples: ['data:image/gif;base64,xxxx=='] }, { title: '数字/货币金额(支持负数、千分位分隔符)', rule: /^-?\d{1,3}(,\d{3})*(\.\d{1,2})?$/ , examples: [100, -0.99, 3, 234.32, -1, 900, 235.09, '12,345,678.90'] }, { title: '银行卡号(10到30位, 覆盖对公/私账户, 参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1))', rule: /^[1-9]\d{9,29}$/, examples: [6234567890, 6222026006705354217] }, { title: '中文姓名', rule: /^(?:[\u4e00-\u9fa5·]{2,16})$/, examples: ['葛二蛋', '凯文·杜兰特', '德克·维尔纳·诺维茨基'] }, { title: '英文姓名', rule: /(^[a-zA-Z][a-zA-Z\s]{0,20}[a-zA-Z]$)/, examples: ['James', 'Kevin Wayne Durant', 'Dirk Nowitzki'] }, { title: '车牌号(新能源)', rule: /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z](([DF]((?![IO])[a-zA-Z0-9](?![IO]))[0-9]{4})|([0-9]{5}[DF]))$/, examples: ['京AD92035', '甘G23459F', '京A19203D'], }, { title: '车牌号(非新能源)', rule: /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]$/, examples: ['京A00599', '黑D23908'] }, { title: '车牌号(新能源+非新能源)', rule: /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4,5}[A-HJ-NP-Z0-9挂学警港澳]$/, examples: ['京A12345D', '京A00599', '京AD92035', '甘G23459F', '京AA92035'], counterExamples: ['宁AD1234555555', '浙苏H6F681'] }, { title: '手机号(mobile phone)中国(严谨), 根据工信部最新公布的手机号段', rule: /^(?:(?:\+|00)86)?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[01256789]))\d{8}$/, examples: ['008618311006933', '+8617888829981', '19119255642', '19519255642'] }, { title: '手机号(mobile phone)中国(宽松), 只要是13,14,15,16,17,18,19开头即可', rule: /^(?:(?:\+|00)86)?1[3-9]\d{9}$/, examples: ['008618311006933', '+8617888829981', '19119255642'] }, { title: '手机号(mobile phone)中国(最宽松), 只要是1开头即可, 如果你的手机号是用来接收短信, 优先建议选择这一条', rule: /^(?:(?:\+|00)86)?1\d{10}$/, examples: ['008618311006933', '+8617888829981', '19119255642'] }, { title: '日期(宽松)', rule: /^\d{1,4}(-)(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31)$/, examples: ['1990-12-12', '1-1-1', '0000-1-1'], counterExamples: ['2020-00-01'] }, { title: '日期(严谨, 支持闰年判断)', rule: /^(([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29)$/, examples: ['1990-12-12', '2000-02-29'], counterExamples: ['2021-02-29'] }, { title: '中国省', rule: /^浙江|上海|北京|天津|重庆|黑龙江|吉林|辽宁|内蒙古|河北|新疆|甘肃|青海|陕西|宁夏|河南|山东|山西|安徽|湖北|湖南|江苏|四川|贵州|云南|广西|西藏|江西|广东|福建|台湾|海南|香港|澳门$/, examples: ['浙江', '台湾'], counterExamples: ['哈尔滨'] }, { title: '可以被moment转化成功的时间 YYYYMMDD HH:mm:ss', rule: /^\d{4}([/:-\S])(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31) (?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/, examples: ['2020/01/01 23:59:59', '2020-01-01 00:00:00', '20200101 11:11:11'], counterExamples: ['2020/00/01 23:59:59', '2020-01/01 23:59:59', '2020-01-01 23:59:61', '2020-01-0100:00:00',] }, { title: 'email(邮箱)', rule: /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/, examples: ['90203918@qq.com', 'nbilly@126.com', '汉字@qq.com'] }, { title: '座机(tel phone)电话(国内),如: 0341-86091234', rule: /^(?:(?:\d{3}-)?\d{8}|^(?:\d{4}-)?\d{7,8})(?:-\d+)?$/, examples: ['0936-4211235', '89076543', '010-12345678-1234'] }, { title: '身份证号(1代,15位数字)', rule: /^[1-9]\d{7}(?:0\d|10|11|12)(?:0[1-9]|[1-2][\d]|30|31)\d{3}$/, examples: ['123456991010193'] }, { title: '身份证号(2代,18位数字),最后一位是校验位,可能为数字或字符X', rule: /^[1-9]\d{5}(?:18|19|20)\d{2}(?:0[1-9]|10|11|12)(?:0[1-9]|[1-2]\d|30|31)\d{3}[\dXx]$/, examples: ['12345619991205131x'] }, { title: '身份证号, 支持1/2代(15位/18位数字)', rule: /^\d{6}((((((19|20)\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|(((19|20)\d{2})(0[13578]|1[02])31)|((19|20)\d{2})02(0[1-9]|1\d|2[0-8])|((((19|20)([13579][26]|[2468][048]|0[48]))|(2000))0229))\d{3})|((((\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|((\d{2})(0[13578]|1[02])31)|((\d{2})02(0[1-9]|1\d|2[0-8]))|(([13579][26]|[2468][048]|0[048])0229))\d{2}))(\d|X|x)$/, examples: ['622223199912051311', '12345619991205131x', '123456991010193'] }, { title: '护照(包含香港、澳门)', rule: /(^[EeKkGgDdSsPpHh]\d{8}$)|(^(([Ee][a-fA-F])|([DdSsPp][Ee])|([Kk][Jj])|([Mm][Aa])|(1[45]))\d{7}$)/, examples: ['s28233515', '141234567', '159203084', 'MA1234567', 'K25345719'] }, { title: '帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线组合', rule: /^[a-zA-Z]\w{4,15}$/, examples: ['justin', 'justin1989', 'justin_666'] }, { title: '中文/汉字', // rule: /^[\u4E00-\u9FA5]+$/, rule: /^(?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])+$/, examples: ['正则', '前端'] }, { title: '小数(支持科学计数)', rule: /^[+-]?(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)$/, examples: ['0.0', '0.09','4E+4'] }, { title: '只包含数字', rule: /^\d+$/, examples: [12345678] }, { title: 'html标签(宽松匹配)', rule: /<(\w+)[^>]*>(.*?<\/\1>)?/, examples: ['
2333
', '', '
'] }, { title: '匹配中文汉字和中文标点', rule: /[\u4e00-\u9fa5|\u3002|\uff1f|\uff01|\uff0c|\u3001|\uff1b|\uff1a|\u201c|\u201d|\u2018|\u2019|\uff08|\uff09|\u300a|\u300b|\u3008|\u3009|\u3010|\u3011|\u300e|\u300f|\u300c|\u300d|\ufe43|\ufe44|\u3014|\u3015|\u2026|\u2014|\uff5e|\ufe4f|\uffe5]/, examples: ["匹配中文汉字以及中文标点符号 。 ? ! , 、 ; : “ ” ‘ ' ( ) 《 》 〈 〉 【 】 『 』 「 」 ﹃ ﹄ 〔 〕 … — ~ ﹏ ¥"] }, { title: 'qq号格式正确', rule: /^[1-9][0-9]{4,10}$/, examples: [903013545, 9020304] }, { title: '数字和字母组成', rule: /^[A-Za-z0-9]+$/, examples: ['james666', 'haha233hi'] }, { title: '英文字母', rule: /^[a-zA-Z]+$/, examples: ['Russel'] }, { title: '小写英文字母组成', rule: /^[a-z]+$/, examples: ['russel'] }, { title: '大写英文字母', rule: /^[A-Z]+$/, examples: ['ABC', 'KD'] }, { title: '密码强度校验,最少6位,包括至少1个大写字母,1个小写字母,1个数字,1个特殊字符', rule: /^\S*(?=\S{6,})(?=\S*\d)(?=\S*[A-Z])(?=\S*[a-z])(?=\S*[!@#$%^&*? ])\S*$/, examples: ['Kd@curry666'] }, { title: '用户名校验,4到16位(字母,数字,下划线,减号)', rule: /^[\w-]{4,16}$/, examples: ['xiaohua_qq'] }, { title: 'ip-v4[:端口]', rule: /^((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.){3}(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])(?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$/, examples: ['172.16.0.0', '172.16.0.0:8080', '127.0.0.0', '127.0.0.0:998'] }, { title: 'ip-v6[:端口]', rule: /(^(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))$)|(^\[(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))\](?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$)/i, examples: ['2031:0000:130f:0000:0000:09c0:876a:130b', '[2031:0000:130f:0000:0000:09c0:876a:130b]:8080'] }, { title: '16进制颜色', rule: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}|[a-fA-F0-9]{8}|[a-fA-F0-9]{4})$/, examples: ['#f00', '#F90', '#000', '#fe9de8', '#f8f8f8ff', '#f003'] }, { title: '微信号(wx),6至20位,以字母开头,字母,数字,减号,下划线', rule: /^[a-zA-Z][-_a-zA-Z0-9]{5,19}$/, examples: ['github666', 'kd_-666'] }, { title: '邮政编码(中国)', rule: /^(0[1-7]|1[0-356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[0-5]|8[013-6])\d{4}$/, examples: ['734500', '100101'] }, { title: '中文和数字', rule: /^((?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])|(\d))+$/, examples: ['哈哈哈', '你好6啊'] }, { title: '不能包含字母', rule: /^[^A-Za-z]*$/, examples: ['你好6啊', '@¥()!'] }, { title: 'java包名', rule: /^([a-zA-Z_]\w*)+([.][a-zA-Z_]\w*)+$/, examples: ['com.bbb.name'] }, { title: 'mac地址', rule: /^(([a-f0-9][0,2,4,6,8,a,c,e]:([a-f0-9]{2}:){4})|([a-f0-9][0,2,4,6,8,a,c,e]-([a-f0-9]{2}-){4}))[a-f0-9]{2}$/i, examples: ['38:f9:d3:4b:f5:51', '00-0C-29-CA-E4-66'] }, { title: '匹配连续重复的字符', rule: /(.)\1+/, examples: ['我我我', '112233', '11234'] }, { title: '数字和英文字母组成,并且同时含有数字和英文字母', rule: /^(?=.*[a-zA-Z])(?=.*\d).+$/, examples: ['我a我1我', 'a对1'] }, { title: '香港身份证 ', rule: /^[a-zA-Z]\d{6}\([\dA]\)$/, examples: ['K034169(1)'] }, { // 参考: // https://baike.baidu.com/item/%E6%BE%B3%E9%97%A8%E5%B1%85%E6%B0%91%E8%BA%AB%E4%BB%BD%E8%AF%81/12509098?fr=aladdin#5 title: '澳门身份证 ', rule: /^[1|5|7]\d{6}\(\d\)$/, examples: ['5686611(1)'] }, { title: '台湾身份证 ', rule: /^[a-zA-Z][0-9]{9}$/, examples: ['U193683453'] }, { title: '大写字母,小写字母,数字,特殊符号 `@#$%^&*`~()-+=` 中任意3项密码', rule: /^(?![a-zA-Z]+$)(?![A-Z0-9]+$)(?![A-Z\W_!@#$%^&*`~()-+=]+$)(?![a-z0-9]+$)(?![a-z\W_!@#$%^&*`~()-+=]+$)(?![0-9\W_!@#$%^&*`~()-+=]+$)[a-zA-Z0-9\W_!@#$%^&*`~()-+=]/, examples: ['a1@', 'A1@', 'Aa@'] }, { title: 'ASCII码表中的全部的特殊字符', rule: /[\x21-\x2F\x3A-\x40\x5B-\x60\x7B-\x7E]+/, examples: ["[", ".", "^", "&3%"] }, { title: '正整数,不包含0', rule: /^\+?[1-9]\d*$/, examples: [1231] }, { title: '负整数,不包含0', rule: /^-[1-9]\d*$/, examples: [-1231] }, { title: '整数', rule: /^(?:0|(?:-?[1-9]\d*))$/, examples: [-1231, 123, 0], counterExamples: ['01'] }, { title: '浮点数', rule: /^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9]\d*|0\.0+)$/, examples: ["1.23", "-1.01", "0.00"] // allow "1.23", allow "-0.1", allow "0.00", ban "-0.00", ban "2.", allow "2.0" }, { title: '浮点数(严格)', rule: /^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9])$/, examples: ["1.23", "-1.01"] // allow "1.23", allow "-0.1", ban "2.", ban "2.0" }, { title: 'email(支持中文邮箱)', rule: /^[A-Za-z0-9\u4e00-\u9fa5]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/, examples: ['90203918@qq.com', 'nbilly@126.com', '啦啦啦@126.com'] }, { title: '域名(非网址, 不包含协议)', rule: /^([0-9a-zA-Z-]{1,}\.)+([a-zA-Z]{2,})$/, examples: ['www.baidu.com', 'baidu.com', 'baidu.com.cn', 'api.baidu.com', 'nodejs.org', 'nodejs.cn'], counterExamples: ['http://baidu.com', 'https://baidu.com', 'www.百度.com'] }, { title: '军官/士兵证', rule: /^[\u4E00-\u9FA5](字第)([0-9a-zA-Z]{4,8})(号?)$/, examples: ['军字第2001988号', '士字第P011816X号'], }, { title: '户口薄', rule: /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/, examples: ['441421999707223115'], }, ]; ================================================ FILE: packages/www/src/main.js ================================================ import Vue from 'vue' import App from './App.vue' Vue.config.productionTip = false if ('serviceWorker' in navigator) { window.addEventListener('load', function() { navigator.serviceWorker.register('./sw.js'); }); } new Vue({ render: h => h(App), }).$mount('#app') ================================================ FILE: packages/www/vue.config.js ================================================ module.exports = { // publicPath: process.env.NODE_ENV === 'production' // ? '/any-rule/' // : '/' } ================================================ FILE: scripts/genCommond.js ================================================ const RULES = require('../packages/www/src/RULES.js'); const pkg = require('../package.json'); const fs = require('fs'); const chalk = require('chalk'); pkg.activationEvents = ['*']; pkg.contributes.commands = RULES.map((rule, index) => ({ command: 'extension.rule' + index, title: `$(rocket) zz: ${rule.title}` })); pkg.contributes.commands.push({ command: 'extension.rule.callByMenu', title: `🦕正则大全(${RULES.length}条)` }); // console.log(JSON.stringify(pkg)); fs.writeFileSync('./package.json', JSON.stringify(pkg, null, 4), 'utf8'); console.log(chalk.green('🚀 pkg文件修改完毕, 请等待生成vsc包...')); ================================================ FILE: scripts/md.js ================================================ const fs = require('fs'); const chalk = require('chalk'); const json = require('../packages/www/src/RULES'); const VSC_URL = 'https://marketplace.visualstudio.com/items?itemName=russell.any-rule' const badges = [ // `![](https://img.shields.io/badge/状态-积极更新-673ab7.svg)`, `![已收录${json.length}条](https://img.shields.io/badge/已收录-${json.length}条-673ab7.svg)`, `[![版本](https://badgen.net/vs-marketplace/v/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule)`, `[![安装量](https://badgen.net/vs-marketplace/i/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule)`, `[![下载量](https://badgen.net/vs-marketplace/d/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule)`, `![MIT](https://img.shields.io/badge/license-MIT-F44336.svg)`, `[![CircleCI](https://badgen.net/github/status/any86/any-rule/master/ci/circleci)](https://circleci.com/gh/any86/any-rule)` // vscode上传不让用svg // `[![Node CI](https://github.com/any86/any-rule/workflows/Node%20CI/badge.svg)](https://github.com/any86/any-rule/actions)` ]; let content = `# 正则大全 ${badges.join(' ')} 🦕支持**web** / **vscode** / **idea** / **Alfred Workflow**多平台 ## :rocket:web版本 https://any-rule.vercel.app/ ## 🍭vscode插件 ### 安装 vscode应用商店中搜索"**any-rule**". ### 使用 **方式1:** 1. 按**F1**(mac下fn+F1)打开正则列表. 2. **输入关键词搜索**, 比如"手机". ![GIF](https://user-images.githubusercontent.com/8264787/146724787-888a8666-5d2a-4e5e-b383-aec7c53bd312.gif) **方式2:** 右键选择"🦕正则大全". ![GIF](https://user-images.githubusercontent.com/8264787/146725447-4d92caed-2dd0-4f11-91d1-8da9cd8ff08b.gif) **方式3:** 在代码任意位置输入"**@zz**". ![GIF](https://user-images.githubusercontent.com/8264787/146725402-30b34119-b709-4d49-adb2-af8dbb786d3b.gif) ## 👩‍🏫图解正则
查看详情 每次在any-rule中选择正则后会弹出提示, 可点击"🤖图解正则". ![image](https://user-images.githubusercontent.com/8264787/146726200-d97e48c3-df76-4531-8210-b6935fffb997.png) 点击后可以看到正则解析, 方便大家学习. ![image](https://user-images.githubusercontent.com/8264787/146726350-58166bf9-7f7f-4685-86aa-f055d0c0b914.png) **注意**: 图解直接使用了https://regexper.com, 在此对作者表示敬意和感谢.
## 社区版本 社区版本非本人维护, 只是其他开发者使用了any-rule整理的正则内容, 如使用出现问题可直接与其开发者联系. [idea版](https://github.com/zhoriya/idea-rule) [Alfred Workflow版](https://github.com/cccyb/workflows) [hyjs: 函数封装版](https://github.com/heiyehk/hyjs/tree/main/packages/utils) [命令行版本](https://github.com/shenguanjiejie/workwork) [uTools版本](https://github.com/trentlee0/utools-any-rule) ## :fire:关于PR 欢迎大家PR, 步骤如下: 1. **正则**请在**packages/www/src/RULES.js**中添加. 2. 运行\`npm run test:rules\`进行测试. 3. 运行\`npm run build:md\`更新**README.md**. 4. 请务必提交到**develop**分支. 在此感谢大家对**any-rule**做出的贡献! ## 🍔正则 `; json.forEach(({title, rule})=>{ content+= `\r\n### ${title}\r\n`; content+= `\`\`\`javascript\r\n`; content+= `${rule}\r\n\`\`\`\r\n`; }); fs.writeFileSync('./README.md',content,'utf-8'); console.log(chalk.green('生成完毕')); ================================================ FILE: src/extension.ts ================================================ // The module 'vscode' contains the VS Code extensibility API // Import the module and reference it with the alias vscode in your code below import { ExtensionContext } from 'vscode'; const RULES: { title: string, rule: RegExp, examples: string[] }[] = require('../packages/www/src/RULES.js'); import useCommand from './useCommand'; import useQuickPick from './useQuickPick'; import useMenuCommand from './useMenuCommand'; export function activate(context: ExtensionContext) { useCommand(context, RULES); useQuickPick(context, RULES); useMenuCommand(context, RULES); } export function deactivate() { } ================================================ FILE: src/insertLog.ts ================================================ import axios from 'axios'; import {version ,env} from 'vscode'; import {getCodeLanguage,getExtensionVersion} from './shared'; const http = axios.create({ baseURL: 'https://leancloud.cn:443/1.1/classes/', timeout: 1000, headers: { "X-LC-Id": "BKaqtaJScQuqKtkAyl5jeloo-gzGzoHsz", "X-LC-Key": "y41qiVPTwnzLIgbDcEzcwHit", "Content-Type": "application/json" } }); /** * 插入日志 */ export default function ({ rule, title, method }: { rule: string, title: string, method: string }) { const {language,machineId} = env; http.post('https://leancloud.cn:443/1.1/classes/Log', { vscodeVersion: version, codeLanguage: getCodeLanguage(), language, machineId, rule, title, extensionVersion:getExtensionVersion(), method }); }; ================================================ FILE: src/interface.d.ts ================================================ export interface IRule { title: string; keywords?: string[]; regex?: RegExp | string; rules?: IRule[]; examples?: string[]; } export interface Rule{ title:string, rule:RegExp, examples:string[] } ================================================ FILE: src/shared.ts ================================================ import { extensions, window} from 'vscode'; /** * 获取编程语言 */ export function getCodeLanguage():string{ return window.activeTextEditor ? window.activeTextEditor.document.languageId as string : ''; }; /** * 获取插件版本号 */ export function getExtensionVersion():string|void { const e = extensions.getExtension('russell.any-rule'); return e && e.packageJSON.version; } ================================================ FILE: src/showResultMessage.ts ================================================ import { extensions, window, version, env, Uri, languages } from 'vscode'; import { getCodeLanguage, getExtensionVersion } from './shared' import insertLog from './insertLog'; const BUTTON_FEEDBACK = '✋意见反馈'; const BUTTON_DIAGRAMMATIZE = '👩‍🏫图解正则'; const BUTTON_CANCEL = '关闭'; export default function (title: string, rule: string): void { // window.setStatusBarMessage(`已插入正则: "${title}", 点击查看更多🔥`) window.showInformationMessage(`已插入正则: "${title}"`, BUTTON_DIAGRAMMATIZE, BUTTON_FEEDBACK, BUTTON_CANCEL).then(value => { if (BUTTON_FEEDBACK === value) { insertLog({ rule, title, method: BUTTON_FEEDBACK }); const URL = Uri.parse(genGithubIssueURL(title)); env.openExternal(URL); } else if (BUTTON_DIAGRAMMATIZE === value) { insertLog({ rule, title, method: BUTTON_DIAGRAMMATIZE }); const URL = Uri.parse(`https://regexper.com/#${rule}`); env.openExternal(URL); } }); } // gihub issue模板 function genGithubIssueURL(title: string): string { const BASE_URL = 'https://github.com/any86/any-rule/issues/new'; const TITLE = `title=[vscode feedback] ${title}`; // const BODY = `body=### vscode version // ${version} // ### extension version // ${getExtensionVersion()} // ### code language // ${getCodeLanguage()} // ### comment // 请留言... // `; return BASE_URL + '?' + TITLE; } ================================================ FILE: src/test/runTest.ts ================================================ import * as path from 'path'; import { runTests } from 'vscode-test'; async function main() { try { // The folder containing the Extension Manifest package.json // Passed to `--extensionDevelopmentPath` const extensionDevelopmentPath = path.resolve(__dirname, '../../'); // The path to test runner // Passed to --extensionTestsPath const extensionTestsPath = path.resolve(__dirname, './suite/index'); // Download VS Code, unzip it and run the integration test await runTests({ extensionDevelopmentPath, extensionTestsPath }); } catch (err) { console.error('Failed to run tests'); process.exit(1); } } main(); ================================================ FILE: src/test/suite/extension.test.ts ================================================ import * as assert from 'assert'; import { before } from 'mocha'; // You can import and use all API from the 'vscode' module // as well as import your extension to test it import * as vscode from 'vscode'; // import * as myExtension from '../extension'; suite('Extension Test Suite', () => { before(() => { vscode.window.showInformationMessage('Start all tests.'); }); test('Sample test', () => { assert.equal(-1, [1, 2, 3].indexOf(5)); assert.equal(-1, [1, 2, 3].indexOf(0)); }); }); ================================================ FILE: src/test/suite/index.ts ================================================ import * as path from 'path'; import * as Mocha from 'mocha'; import * as glob from 'glob'; export function run(): Promise { // Create the mocha test const mocha = new Mocha({ ui: 'tdd', }); mocha.useColors(true); const testsRoot = path.resolve(__dirname, '..'); return new Promise((c, e) => { glob('**/**.test.js', { cwd: testsRoot }, (err, files) => { if (err) { return e(err); } // Add files to the test suite files.forEach(f => mocha.addFile(path.resolve(testsRoot, f))); try { // Run the mocha test mocha.run(failures => { if (failures > 0) { e(new Error(`${failures} tests failed.`)); } else { c(); } }); } catch (err) { e(err); } }); }); } ================================================ FILE: src/useCommand.ts ================================================ import { window, commands, Range, ExtensionContext } from "vscode"; import { Rule } from './interface'; import insertLog from './insertLog'; import showResultMessage from './showResultMessage'; export default function (context: ExtensionContext, RULES: Rule[]) { RULES.forEach(({ title, rule }, index) => { const ruleString = String(rule); const disposable = commands.registerCommand(`extension.rule${index}`, () => { const editor = window.activeTextEditor; if (editor) { const { selections } = editor; editor.edit(editBuilder => { selections.forEach(selection => { const { start, end } = selection; const range = new Range(start, end); editBuilder.replace(range, ruleString); }); }); // 日志 insertLog({ rule: ruleString, title, method: 'Command' }); showResultMessage(title, ruleString); } else { window.showWarningMessage('any-rule: 只有在编辑文本的时候才可以使用!'); } }); context.subscriptions.push(disposable); }); } ================================================ FILE: src/useMenuCommand.ts ================================================ import { window, commands, Range, ExtensionContext } from "vscode"; import { Rule } from './interface'; import insertLog from './insertLog'; import showResultMessage from './showResultMessage'; export default function (context: ExtensionContext, RULES: Rule[]) { const disposable = commands.registerCommand(`extension.rule.callByMenu`, () => { // showQuickPick window.showQuickPick(RULES.map(({ examples, title, rule }) => { // const match = title.match(/\((.+)\)/); return { label: title, // description: null !== match ? match[1] : '', rule: String(rule), // 非标准字段, 仅仅为了传值 detail: `例如: ${examples.join(' 或 ')}` }; }), { placeHolder: '请输入关键词', // onDidSelectItem(item){ // console.log(item) // } }).then(item => { if (!item) return const editor = window.activeTextEditor; if (editor) { const ruleString = String(item.rule); const title = item.label; const { selections } = editor; editor.edit(editBuilder => { selections.forEach(selection => { const { start, end } = selection; const range = new Range(start, end); editBuilder.replace(range, ruleString); }); }); // 日志 insertLog({ rule: ruleString, title, method: 'Menu' }); showResultMessage(title, ruleString); } }); }); context.subscriptions.push(disposable); } ================================================ FILE: src/useQuickPick.ts ================================================ import { ExtensionContext, workspace, languages, window, TextDocument, Position, Range, Selection } from "vscode"; import { Rule } from './interface'; // import { slugify } from 'transliteration'; import insertLog from './insertLog'; import showResultMessage from './showResultMessage'; export default function (context: ExtensionContext, RULES: Rule[]) { // commands.registerCommand('functions.insertRegex', insertRule); // 不确定是不是都兼容"*", 保守 let { supportedLanguages, triggerStringEnd } = getConfig(); workspace.onDidChangeConfiguration(() => { const config = getConfig(); supportedLanguages = config.supportedLanguages; triggerStringEnd = config.triggerStringEnd; }); const disposable = languages.registerCompletionItemProvider(supportedLanguages.split(','), { provideCompletionItems(document, position) { const { triggerString } = getConfig(); // 如果为空表示关闭 if (!triggerString) return []; const linePrefix = document.lineAt(position).text.substr(0, position.character); if (!linePrefix.endsWith(triggerString)) return []; // 滞后执行 setTimeout(() => { // showQuickPick window.showQuickPick(RULES.map(({ examples, title, rule }) => { // const match = title.match(/\((.+)\)/); return { label: title, // description: null !== match ? match[1] : '', rule: String(rule), // 非标准字段, 仅仅为了传值 detail: `例如: ${examples.join(' 或 ')}` }; }), { placeHolder: '请输入关键词', // onDidSelectItem(item){ // console.log(item) // } }).then(item => { if (!item) return insertRule(document, position, item.rule); // 日志 insertLog({ rule: item.rule, title: item.label, method: 'QuickPick' }); showResultMessage(item.label, item.rule); }); }, 10) return []; }, resolveCompletionItem(item) { return item; } }, triggerStringEnd); context.subscriptions.push(disposable); } function insertRule(document: TextDocument, position: Position, ruleString: string) { const { triggerString } = getConfig(); const editor = window.activeTextEditor; if (void 0 === editor) return; editor.edit(editBuilder => { const line = document.lineAt(position); // 起始, "zz."前面的位置 const startPostion = position.translate(0, -triggerString.length); editBuilder.replace(new Range(startPostion, position), ruleString); setTimeout(() => { // 全选正则字符串 const endPostion = new Position(line.lineNumber, startPostion.character + ruleString.length); editor.selection = new Selection(startPostion, endPostion); }, 0); }); } // 获取配置 function getConfig() { const configuration = workspace.getConfiguration(); const { triggerString, supportedLanguages } = configuration['any-rule']; const { length } = triggerString; const triggerStringStart = triggerString.substr(0, length - 1); const triggerStringEnd = triggerString.substr(-1); console.log(supportedLanguages); return { triggerStringStart, triggerStringEnd, triggerString, // 预留 supportedLanguages } } ================================================ FILE: tsconfig.json ================================================ { "compilerOptions": { "module": "commonjs", "target": "es6", "outDir": "out", "lib": [ "es6" ], "sourceMap": true, "rootDir": "src", "strict": true /* enable all strict type-checking options */ /* Additional Checks */ // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ // "noUnusedParameters": true, /* Report errors on unused parameters. */ }, "exclude": [ "node_modules", ".vscode-test" ] } ================================================ FILE: tslint.json ================================================ { "rules": { "no-string-throw": true, "no-unused-expression": true, "no-duplicate-variable": true, "curly": true, "class-name": true, "semicolon": [ true, "always" ], "triple-equals": true }, "defaultSeverity": "warning" } ================================================ FILE: webpack.config.js ================================================ // @ts-check 'use strict'; const path = require('path'); /**@type {import('webpack').Configuration}*/ const config = { target: 'node', // vscode extensions run in a Node.js-context 📖 -> https://webpack.js.org/configuration/node/ entry: './src/extension.ts', // the entry point of this extension, 📖 -> https://webpack.js.org/configuration/entry-context/ output: { // the bundle is stored in the 'dist' folder (check package.json), 📖 -> https://webpack.js.org/configuration/output/ path: path.resolve(__dirname, 'out'), filename: 'extension.js', libraryTarget: 'commonjs2', devtoolModuleFilenameTemplate: '../[resource-path]' }, devtool: 'source-map', externals: { vscode: 'commonjs vscode' // the vscode-module is created on-the-fly and must be excluded. Add other modules that cannot be webpack'ed, 📖 -> https://webpack.js.org/configuration/externals/ }, resolve: { // support reading TypeScript and JavaScript files, 📖 -> https://github.com/TypeStrong/ts-loader extensions: ['.ts', '.js'] }, module: { rules: [ { test: /\.ts$/, exclude: /node_modules/, use: [ { loader: 'ts-loader' } ] } ] } }; module.exports = config;