linux字符过滤
1 案例一:取eth0的IP地址
方法一:通过cut方法过滤
[root@baiguin ~]# ifconfig eth0|grep "inet addr:"|cut -d ":" -f2|cut -d " " -f1
192.168.26.132
===============================================================
方法二:通过awk方法过滤
1)[root@baiguin ~]# ifconfig eth0 |grep "inet addr:" |awk -F: '{print $2 }'|awk '{print $1}'
192.168.26.132
2)[root@baiguin ~]# ifconfig eth0 |grep "inet addr:" |awk -F "[ :]" '{print $13}'
192.168.26.132
3)[root@baiguin ~]# ifconfig eth0 |grep "inet addr:" |awk -F "[ :]+" '{print $4}'
192.168.26.132
4)[root@baiguin ~]# ifconfig eth0 |awk -F '[ :]+' '{if(NR==2) print $4}'
192.168.26.132192.168.26.132
[root@baiguin ~]# ifconfig eth0|grep "inet addr:"|awk -F "[ :]*" '{print $4}'
192.168.26.132
注:此中的“+”和“*”号即正则表达式用法
===========================================================
方法三:通过sed方法过滤
1)[root@baiguin ~]# ifconfig eth0|sed -n "s/^.*addr:\(.*\) Bcast.*$/\1/gp"
192.168.26.132
注:sed小括号()分组功能
Sed ‘s/ /
/g’
部分可以用正则表达式,
的部分不能用正则表达式。
()是分组(group),再 部分使用()括起来的内容,再
的位置可以使用\1调用前面括号内的内容。
如果有多个的括号,那么依次是\2,\3调用 第二个第三个括号,以此类推。
eg:
[root@baiguin ~]# echo "aaa bbb" >a.txt
[root@baiguin ~]# cat a.txt
aaa bbb
[root@baiguin ~]# sed 's#\(aaa\) \(bbb\)#\1#g' a.txt
aaa
[root@baiguin ~]# sed 's#\(aaa\) \(bbb\)#\2#g' a.txt
bbb
[root@baiguin ~]# sed 's#\(.*\) \(.*\)#\2#g' a.txt
bbb
[root@baiguin ~]# sed 's#\(.*\) \(.*\)#\1#g' a.txt
aaa
2) [root@baiguin ~]# ifconfig eth0|sed -n 2p|sed -n "s/^.*addr:\(.*\) Bcast.*$/\1/gp"
192.168.26.132
3)[root@baiguin ~]# ifconfig eth0 |sed -n 2p |sed 's#^.*addr:##g'|sed 's# Bcas.*$##g'
192.168.26.132
2 如何取得wang.txt的权限对应的数字内容(如-rw-r-r-为644,要求使用命令取得644或0644数字)
1)通过Sed正则进行截取
[root@baiguin ~]# stat wang.txt |sed -n 's#^.*(0\(.*\)/-.*$#\1#gp'
644
2)通过awk正则进行截取
[root@baiguin ~]# stat wang.txt |awk -F "[: (0]+" '{if (NR==4) print $2}'|cut -d"/" -f1
644
[root@baiguin ~]# stat wang.txt |awk -F "[(0/]" '{if (NR==4) print $3}'
644
3)通过命令直接取
[root@baiguin ~]# stat -c %a wang.txt
644
注:可“man stat”查看参数
4)另外思考方法
[root@baiguin ~]# ls -l wang.txt |cut -c 2-10|tr rwx- 4210|awk -F "" '{print $1+$2+$3,$4+$5+$6,$7+$8+$9}'|sed 's# ##g'
644
注:tr rwx- 4210的用法
3 一些文件被黑客植入一样的病毒,如何将这些文件相同的病毒代码删除。
步骤:
1)先模拟创建几个文件,并在文件中随意输入一些内容。
[root@baiguin ~]# touch wang/w.txt wang/bai/b.txt wang/bai/gui/g.txt
2)用find查找出wang目录下所有的文件,并通过xargs命令将需要添加的病毒依次添加进去。
[root@baiguin ~]# find wang -type f |xargs sed -i '1 i <11111111111111111111111111111>'
注:注意sed后-i命令的用法
3)在生产环境中,要替换文件时需先全部备份,以防二次破坏文件。在此编写一脚本进入对要替换的文件做备份。
[root@baiguin ~]# cat test.sh
file=`find /root/wang -type f >1.txt`
filename=`cat 1.txt`
for i in $filename;do
cp $i /bak
done
[root@baiguin ~]# sh test.sh
[root@baiguin ~]# ls /bak/
b.txt g.txt w.txt
4)通过sed将相同的命令全部替换成空删除
查看到每个文件都有相同的字符
[root@baiguin ~]# cat wang/w.txt
<1111111111111111111111111111111111111111111111111111111>
<dsfaasdfasdfsadffdfsdafddsfasd>
dfajdf
[root@baiguin ~]# cat wang/bai/b.txt
<1111111111111111111111111111111111111111111111111111111>
sdfdfsdf
sdf
解决办法:通过sed命令删除
[root@baiguin ~]# find wang -type f |xargs sed -i '/<1111111111111111111111111111111111111111111111111111111>/d'
或
[root@baiguin ~]# find wang -type f |xargs sed -i '/^.*1111111111>/d'
再次查看,看替换结果。
[root@baiguin ~]# cat wang/w.txt
<dsfaasdfasdfsadffdfsdafddsfasd>
dfajdf
[root@baiguin ~]# cat wang/bai/b.txt
sdfdfsdf
sdf
结果成功!
4 通过tar打包,并以时间date格式打包包名。
[root@baiguin ~]# tar zcvf wang-$(date +%F).bak wang
[root@baiguin ~]# ls wang-2014-09-26.bak
wang-2014-09-26.bak
案例:
如果只希望保存一周的包,按常规方法需要通过手动删除一周前的包。但可通过date的w参数,来只保存7天,之后循环覆盖即可。
[root@baiguin ~]# tar zcvf wang-$(date +%w).bak wang
[root@baiguin ~]# ls wang-5.bak
5 下列快捷键含义
Ctrl + a ; 光标到行的开头
Ctrl + e ; 光标到行的结尾
Ctrl + d ; 退出当前窗口,或当前用户
Ctrl + l ; 清屏或clear命令
Ctrl + u ; 删除光标前面行的内容
Ctrl + k ; 删除光标后面行的内容
Ctrl + s ; 锁住屏幕
Ctrl + q ; 解锁屏幕
linux字符过滤的更多相关文章
- linux复习3:linux字符界面的操作
一.前言 1.对linux服务器进行管理的时候,经常要进入字符界面进行操作,使用命令需要记住该命令的相关选项和参数.vi编辑器可以用于编辑任何ASCII文本,功能非常的强大,可以对文本进行创建.查找. ...
- 深入理解Linux字符设备驱动
文章从上层应用访问字符设备驱动开始,一步步地深入分析Linux字符设备的软件层次.组成框架和交互.如何编写驱动.设备文件的创建和mdev原理,对Linux字符设备驱动有全面的讲解.本文整合之前发表的& ...
- Linux字符设备驱动结构(一)--cdev结构体、设备号相关知识机械【转】
本文转载自:http://blog.csdn.net/zqixiao_09/article/details/50839042 一.字符设备基础知识 1.设备驱动分类 linux系统将设备分为3类:字符 ...
- Smart210学习记录----beep linux字符设备驱动
今天搞定了beep linux字符设备驱动,心里还是很开心的,哈哈...但在完成的过程中却遇到了一个非常棘手的问题,花费了我大量的时间,,,, 还是把问题描述一下吧,好像这个问题很普遍的,网上许多解决 ...
- java 非法字符过滤 , 半角/全角替换
java 非法字符过滤 , 半角/全角替换 package mjorcen.netty.test1; import java.io.UnsupportedEncodingException; publ ...
- Linux字符设备中的两个重要结构体(file、inode)
对于Linux系统中,一般字符设备和驱动之间的函数调用关系如下图所示 上图描述了用户空间应用程序通过系统调用来调用程序的过程.一般而言在驱动程序的设计中,会关系 struct file 和 struc ...
- Linux 字符驱动程序(一)
Linux 字符驱动程序(一) 于linux有三个主要的内核设备: 1 字符设备: •字符设备的读写以字节为单位,存取时没有缓存. •对字符设备发出读写请求时.实际的硬件I/ ...
- 华为-on练习--重复的字符过滤
称号: 请写一个字符串过滤程序,如果使用多个相同的字符出现在字符串中,字符首次出现在非过滤,. 比方字符串"abacacde"过滤结果为"abcde". 演示样 ...
- 两款【linux字符界面下】显示【菜单】,【选项】的powershell脚本模块介绍
两款[linux字符界面下]显示[菜单],[选项]的powershell脚本模块介绍 powershell linux ps1 menu choice Multiselect 传教士 菜单 powe ...
随机推荐
- P.V操作【转】
阐述P,V原语的理论不得不提到的一个人便是赫赫有名的荷兰科学家 E.W.Dijkstra.如果你对这位科学家没有什么印象的话,提起解决图论中最短路径问题的Dijkstra算法应当是我们再熟悉不过的了. ...
- Unity3D Mathf函数
Mathf.Abs绝对值 计算并返回指定参数 f 绝对值. Mathf.Acos反余弦 static function Acos (f : float) : float 以弧度为单位计算并返回参数 f ...
- PC 端 360 云盘初体验
首先吐槽一下安装软件,文件名是 360wangpan,安装好后软件名称是"360云盘",好歹得统一下嘛,不然还以为下错了安装文件呢. 一般使用和其他网盘差不多,速度也还行,但还是没 ...
- c++面试常见160问
1.在C++ 程序中调用被C 编译器编译后的函数,为什么要加extern "C"?答:首先,extern是C/C++语言中表明函数和全局变量作用范围的关键字,该关键字告诉编译器,其 ...
- cocos2d-x 的CCObject与autorelease 之深入分析
转自: http://blog.csdn.net/honghaier/article/details/8160519 CCObject.h: #ifndef __CCOBJECT_H__ #defin ...
- Android FM模块学习之二 FM搜索频率流程
上一篇大概分析了一下FM启动流程,若不了解Fm启动流程的,能够去打开前面的链接先了解FM启动流程,接下来我们简单分析一下FM的搜索频率流程. 在了解源代码之前.我们先看一下流程图: 事实上从图中能够看 ...
- android点滴之标准SD卡状态变化事件广播接收者的注冊
眼下最完整的,须要注冊的动作匹配例如以下: IntentFilter intentFilter = new IntentFilter(Intent.ACTION_MEDIA_MOUNTED); int ...
- jitsi
http://code.csdn.net/openkb/p-Jitsi https://download.jitsi.org/jitsi/nightly/ https://download.jitsi ...
- xml配置和基于java类的bean配置搭配使用
如果同时使用了xml配置,和java类的bean配置(当然估计项目中一般不会这样), 在初始化容器指定资源文件的时候可能会比较麻烦 此时我们可以把基于java类的bean配置整合到xml中,或xml的 ...
- MySQL 权限?
一.权限表 mysql数据库中的3个权限表:user .db. host 权限表的存取过程是: 1)先从user表中的host. user. password这3个字段中判断连接的IP.用户名.密码是 ...