过滤身份证号和grep复习
一、把身份证号过滤出来
我们还是从一道面试题说起。
请从test.txt文件当中过滤出正确的的身份证号码
[root@localhost test.dir]# cat test.txt
赵 370831199405162458
钱 370831199305162kjl
孙 37083119920516245X
李 37083110516245887k
张 37083KKKKKKK990516
在LINUX当中,我们要过滤文本时,我们一定要搞清楚,要过滤的文本有什么特征,那么问题来了,身份证号有什么特征?
- l 身份证号都是18位的
- l 有的身份证号全都是数字,有的身份证号前17位是数字,最后一位是大写的X
好,那事情就简单了!
我们先来满足第一个要求,即身份证号都是18位,18位!如何用正则表达式表示呢?其实无法用基本的正则表达式表达18位数字,需要用到扩展的正则表达式,即:{18};第二个要求就有点麻烦了,最后一位是什么不确定,最后一位要么是数字要么是大写的X,“或”的关系,或的关系用扩展的正则表达式如何表达呢?要用到"|"这个符号,前面的17位数字倒是容易了,数字通过[0-9]就可以表示了。
好,注意了,来了啊!两种方法都可以:
[root@localhost test.dir]# egrep '[0-9]{18}|[0-9]{17}X' test.txt 赵 370831199405162458 孙 37083119920516245X
#查找有18位数字的或者前17位是数字最后一位是X的行,把完全是数字的号码与数字X混杂的号码分开考虑
[root@localhost test.dir]# egrep '[0-9]{17}[0-9X]{1}' test.txt 赵 370831199405162458 孙 37083119920516245X
#查找前17位是数字后面跟一位数字或大写的X的行,把完全是数字的号码与数字X混杂的号码放在一起考虑
好,现在增加难度!现在文件变成这样了:
[root@localhost test.dir]# cat test.txt 赵 370831199405162458 钱 370831199305162kjl 孙 39083119920516245X 陈 37083119920516245X377 李 37083110516245887k 张 37083KKKKKKK990516 [root@localhost test.dir]# egrep '[0-9]{18}|[0-9]{17}X' test.txt 赵 370831199405162458 孙 39083119920516245X 陈 37083119920516245X377 #出现了这个,不符合我们的需求 #为什么不符合要求呢?因为这这一行明显是超过了18位的要求 [root@localhost test.dir]# egrep '[0-9]{17}[0-9X]{1}' test.txt 赵 370831199405162458 孙 39083119920516245X 陈 37083119920516245X377 #出现了这个,不符合我们的需求
怎么办呢?我们怎样才能只过滤出18位的呢?可以这样,如下所示:
[root@localhost test.dir]# egrep '[0-9]{18}|[0-9]{17}X' test.txt -w #对egrep使用-w选项 赵 370831199405162458 孙 39083119920516245X [root@localhost test.dir]# egrep '[0-9]{17}[0-9X]{1}' test.txt -w 赵 370831199405162458 孙 39083119920516245X
-w是什么意思呢?即锚定连续的字符,即锚定单词,仔细体会一下!
二、grep使用复习
grep做为文本三剑客之一,其作用就是用来过滤文本,与单引号匹配,我们在使用grep的时候最好都使用单引号。
它有以下这么几个常用的选项,我们要做简要的描述,然后再举详细的例子
- n:显示行号,是行原本在文本的原始行号
- v:取反
- o:显示过程,可以理解为只显示匹配到的字符而非行,默认grep是行过滤器
- E:使得grep支持扩展的正则表达式,与egrep的效果是一样的
- i:igore case,不区分大小写
- w:我们上面见识过了,即锚定连续的字符,即描写单词
- A2:显示目标行的后面2行,数字可自定义
- B2:显示目标行的前面2行,数字可自定义
- C2:显示目标行的前后各2行,数字可自定义
下面就是例子了:
[root@localhost test.dir]# cat test.txt 赵 370831199405162458 钱 370831199305162kjl 孙 39083119920516245X 陈 37083119920516245X377 李 37083110516245887k 张 37083KKKKKKK990516 [root@localhost test.dir]# grep -n '1993' test.txt #显示行号 2:钱 370831199305162kjl [root@localhost test.dir]# grep -o '1993' test.txt #只显示匹配到的字符,不显示一整行 1993 [root@localhost test.dir]# grep -nv '1993' test.txt #取反 1:赵 370831199405162458 3:孙 39083119920516245X 4:陈 37083119920516245X377 5:李 37083110516245887k 6:张 37083KKKKKKK990516 [root@localhost test.dir]# grep -Ew '[0-9]{18}|[0-9]{17}X' test.txt #-E和-w连用,能看懂吗?不懂再去看看上面的例子哦! 赵 370831199405162458 孙 39083119920516245X [root@localhost test.dir]# grep -E '[k]{7}' test.txt #用小写的K,啥都过滤不出来 [root@localhost test.dir]# grep -Ei '[k]{7}' test.txt #使用了-i选项之后,忽略了大小写,就能把下面这一行过滤出来了。 张 37083KKKKKKK990516 [root@localhost test.dir]# grep -EB2 '[K]{7}' test.txt #把目标内容的上面的两行过滤出来 陈 37083119920516245X377 李 37083110516245887k 张 37083KKKKKKK990516
过滤身份证号和grep复习的更多相关文章
- shell脚本创建身份证号
--作者:飞翔的小胖猪 --创建时间:2021年5月16日 --修改时间:2021年5月16日 说明 运行脚本,用户手动输入信息生成身份证号.该程序的核心在于函数模块化及select的使用. 注意:该 ...
- iOS之由身份证号返回性别
该博文出自:http://www.cnblogs.com/yang-guang-girl/p/5683454.html - (void)viewDidLoad { [super viewDidLoad ...
- input表单手机号、身份证号验证
<form action="" method="post" onsubmit="return checkForm(this)"> ...
- mysql从身份证号中提取生日、性别
SELECT p.ID, p.IDCardNo, IF ( LENGTH(p.IDCardNo) , CAST( , ) AS DATETIME ), CAST( CONCAT( ', , ) ) A ...
- js 随机生成姓名、手机号、身份证号、银行卡号
开发测试的时候,经常需要填写姓名.手机号.身份证号.银行卡号,既要符合格式要求.又不能重复.大家会到网上搜各种生成器.能不能自己写一个简单的生成器呢.下面是随机生成姓名.手机号.身份证号.银行卡号的j ...
- 教你一招:根据身份证号计算出生年月和年龄 text函数和mid函数混用 datedif函数和today函数混用
在电子表格Excel中,使用text函数和mid函数混用,根据身份证号计算出生年月: =text(mid(A2,,),"0!/00!/00") #0!/00!/00 为日期的格式# ...
- C#中使用正则表达式验证电话号码、手机号、身份证号、数字和邮编
验证电话号码的主要代码如下: public bool IsTelephone(string str_telephone) { return System.Text.RegularExpressio ...
- Js 根据身份证号获取年龄-性别
参考:http://www.tuicool.com/articles/J7r2ien 方式一: $scope.GetAgeAndSexByIDNum = function (IdCardNO) { / ...
- 锋利的js之验证身份证号
我们在做互联网网站时,注册个人资料时,经常要用到身份证号,我们需要对身份证进验证,不然别人随便输个号码就通过,让你感觉这个网站做得很shit. 身份证号是有规则的. 结构和形式 1.号码的结构 公民 ...
随机推荐
- c# 第22节 c#四大方法 静态方法、实例方法、虚方法、重新方法
本节内容: 1:静态方法和实例方法什么 2:虚方法是什么 3:重写方法 4:禁止重写方法 1:静态方法和实例方法是什么 静态方法,一般是类的常用方法,允许在不创建类的实例的情况下,直接调用. 静态方法 ...
- window系统下的pycharm对虚拟机中的Ubuntu系统操作MySQL数据库
问题:程序员和数据库的爱情故事:程序为了追一个叫MySQL数据库的姑娘,先苦练功夫,自己模拟泡妹过程积累经验,于是想到一个解决方法:[解决虚拟机跑需要连接数据库的程序卡的问题,通过在物理机Window ...
- 用 FFLIB 实现 Apex 企业设计模式
Apex 企业设计模式将应用分为服务层.模型层.选择逻辑层.工作单元几个部分.FFLIB 是一个开源的 Apex 框架,可以帮助开发者快速建立相关的功能. FFLIB 的安装 FFLIB 可以直接部署 ...
- python中实现单例模式
单例模式的目的是一个类有且只有一个实例对象存在,比如在复用类的过程中,可能重复创建多个实例,导致严重浪费内存,此时就适合使用单例模式. 前段时间需要用到单例模式,就称着机会在网上找了找,有包含了__n ...
- Codeforces Round #596 (Div. 2, based on Technocup 2020 Elimination Round 2) E. Rock Is Push dp
E. Rock Is Push You are at the top left cell (1,1) of an n×m labyrinth. Your goal is to get to the b ...
- 介绍一个比较强大的网页剪藏工具——web-clipper
网址:https://clipper.website/ 在语雀的第三方工具处遇到的. 感觉可以代替印象笔记网页端的剪藏,还是很强大的.
- 【新特性速递】优化Shift/Ctrl行多选逻辑,和Windows的文件资源管理器保持一致!
别告诉我你不知道 别告诉我你不知道可以使用键盘的 Shift 和 Ctrl 来多选表格行,因为这个在 Windows 文件资源管理器中的常用操作,此时的画风是这样的: 这个动图中进行了如下操作: 1. ...
- 三、ForkJoin分析
ForkJoin分析 一.ForkJoin ForkJoin是由JDK1.7后提供多线并发处理框架.ForkJoin的框架的基本思想是分而治之.什么是分而治之?分而治之就是将一个复杂的计算,按照设 ...
- JDBC与Druid简单介绍及Druid与MyBatis连接数据库
序言 java程序与数据建立连接,首先要从jdbc说起,然后直接上阿里认为宇宙最好的数据库连接池druid,然后再说上层程序对象与数据源映射关联关系的orm-mybatis. JDBC介绍 JDBC( ...
- c# 值类型和引用类型 笔记
参考以下博文,我这里只是笔记一下,原文会更加详细 c#基础系列1---深入理解值类型和引用类型 堆栈和托管堆c# 值类型和引用类型 红色表示——“这啥?”(真实1个问题引出3个问题) CLR支持的两种 ...