[转帖]shell脚本实现文本内容比较交互程序
背景介绍
脚本基于Comm命令进行功能封装,考虑到命令执行前需要对文本进行排序,并且在多文件需要比较内容时可能会导致多个文本混乱,因此使用Shell封装成了一个交互式程序,快速对文件内容进行判断和输出想要的内容内容结果。
脚本介绍
- 文件内容校验(是否一致内容)
- 定制化输出文本(1.仅文本单独出现内容;2.共同出现内容)
- 交互式便捷使用
实现代码
!/bin/bash初始化变量
E_CODE=65 #退出状态码
FILE_1=$1 #第一个文本
FILE_2=\(2 #第二个文本
FILE_SUM=\)#传参数检测函数
init(){if [ ! $FILE_SUM -eq 2 ]
then
echo "Usage:$0 filename_1 filename_2 " && exit $E_CODE
fi
}
文本检测
txt_check(){
#传参文件类型检测
if [ ! -f \(FILE_1 ] ;then echo "\)FILE_1文件错误,请检查文件合规性!" && exit E_CODE;fi
if [ ! -f \(FILE_2 ] ;then echo "\)FILE_2文件错误,请检查文件合规性!" && exit E_CODE;fi#传参文件内容是否为空检测
if [ `grep -q '[^[:space:]]' $FILE_1;echo $?` -ne 0 ] ;then echo "${FILE_1##/*/}文件内容为空,请重新选择指定文件!" && exit E_CODE;fi
if [ `grep -q '[^[:space:]]' $FILE_2;echo $?` -ne 0 ] ;then echo "${FILE_2##/*/}文件内容为空,请重新选择指定文件" && exit E_CODE;fi
}
文本内容校验
judge_comm(){
clear
local file12_all file1_line file2_line
#FILE_1文件行数
file1_line=awk '{print $0}' $FILE_1 | wc -l
#FILE_2文件行数
file2_line=awk '{print $0}' $FILE_2 | wc -l
file1_only=comm -2 -3 <(sort $FILE_1) <(sort $FILE_2) | wc -l
file2_only=comm -1 -3 <(sort $FILE_1) <(sort $FILE_2) | wc -l
#相同内容行数
file12_all=comm -1 -2 <(sort $FILE_1) <(sort $FILE_2) | wc -l
#原文件行数和共同行数一致,文件内容相同
if [ "\(file1_line" -eq "\)file12_all" -a "\(file2_line" -eq "\)file12_all" ]
then
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
echo -e "\033[41;37m[\({FILE_1##/*/}]和[\){FILE_2##//}]文件内容完全一致\033[0m"
elif [ "\(file12_all" -eq "0" ]
then
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
echo -e "[\){FILE_1##//}]和[\({FILE_2##/*/}]文件内容不一致,无相同内容\033[0m"
elif [ "\)file12_all" -gt 0 ]
then
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
if [ "\(file1_only" -eq 0 ]
then
echo -e "\033[41;37m[\){FILE_2##//}]包含[\({FILE_1##/*/}]的内容\033[0m"
elif [ "\)file2_only" -eq 0 ]
then
echo -e "\033[41;37m[\({FILE_1##/*/}]包含[\){FILE_2##//}]的内容\033[0m"
else
echo -e "\033[41;37m[\({FILE_1##/*/}]和[\){FILE_2##//}]文件内容不一致\033[0m"
fi
else
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
echo -e "\033[41;37m[\({FILE_1##/*/}]和[\){FILE_2##//}]文件内容不一致\033[0m"
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
echo "部分内容相同,详细内容如下>>> "
comm -1 -2 <(sort $FILE_1) <(sort $FILE_2) || ( echo "Comm -1 -2 执行失败" && exit E_CODE )
fi
}文本比较功能实现
txt_comm(){
#只显示FILE_1才有的内容
if [ \(1 == 1 ]
then
clear
echo -e "\033[42;37m仅在[\){FILE_1##//}]出现的内容\033[0m"
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
comm -2 -3 <(sort $FILE_1) <(sort $FILE_2) || ( echo "Comm -2 -3 执行失败" && exit E_CODE )
echo
#只显示FILE_2才有的内容
elif [ \(1 == 2 ]
then
clear
echo -e "\033[42;37m仅在[\){FILE_2##//}]出现的内容\033[0m"
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
comm -1 -3 <(sort $FILE_1) <(sort $FILE_2) || ( echo "Comm -1 -3 执行失败" && exit E_CODE )
echo
#显示共有内容
elif [ \(1 == 3 ]
then
clear
echo -e "\033[42;37m[\){FILE_1##//}]和[${FILE_2##//}]共同出现的内容\033[0m"
awk 'BEGIN{sum="";for(i=0;i<=30;i++){ sum=sum "="};print sum}'
comm -1 -2 <(sort $FILE_1) <(sort $FILE_2) || ( echo "Comm -1 -2 执行失败" && exit E_CODE )
echo
fi}
打印一级主菜单
menu_1(){
clear
cat<<EOF== Welcome to the file content verification script ===
1.Author:Cosann
2.Function:文件内容校验脚本
3.version:1.0
4.Email:gy17520659076@gmail.com
5.Description:
- 文件内容校验(是否一致内容)
- 定制化输出文本(1.仅文本单独出现内容;2.共同出现内容)
- 交互式便捷使用
======================================================
功能菜单:
1.校验文件内容一致性
2.查看文件详细内容
3.退出程序EOF
获取菜单选项序号
read -p "请输入菜单序号执行对应功能: " menu_nu
}打印二级菜单
menu_2(){
cat<<EOF1.显示仅在[\({FILE_1##/*/}]出现的内容
2.显示仅在[\){FILE_2##/*/}]出现的内容
3.显示两个共同出现的内容
4.返回主菜单EOF
获取菜单选项序号
read -p "请输入序号: " menu_nu2
}返回菜单
f_menu(){
echo
cat<<EOF
- 返回主菜单
- 退出程序
EOF
read -p "请输入序号>>> " menu_nu3
if [ $menu_nu3 -eq "1" ];then
continue
elif [ $menu_nu3 -eq "2" ];then
exit_menu
else
"非法输入,请输入正确序号!"
sleep 0.5
fi
echo
}退出信息
exit_menu(){
cat<<EOF感谢使用,再见~
EOF
exit
}控制函数
main(){
init
txt_check
while :
do
#打印主菜单
menu_1#菜单选项控制
case $menu_nu in
"1")
#echo "菜单选项1"
judge_comm
f_menu
;;
"2")
clear
while :
do
menu_2
case $menu_nu2 in
"1") txt_comm "1" ;;
"2") txt_comm "2" ;;
"3") txt_comm "3" ;;
"4") break ;;
*) echo "错误输入,请输入正确序号!";sleep 0.5 ;;
esac
done
;;
"3")
exit_menu
;;
*)
echo "非法输入,请输入正确序号!"
sleep 0.5
;;
esac
done
}main $*
运行案例
文本


运行程序

结果展示
文件内容校验

菜单选项

仅在某个文本出现的内容

两个文本共同出现的内容

[转帖]shell脚本实现文本内容比较交互程序的更多相关文章
- shell脚本--显示文本内容
shell脚本显示文本内容及相关的常用命令有cat.more.less.head.tail.nl 首先是cat,cat最常用的就是一次性显示文件的所有内容,如果一个文件的内容很多的话,那么就不是很方便 ...
- iOS使用shell脚本注入混淆内容
背景 公司需要做一系列的壳版本,壳版本如果内容雷同提交到App Store会有被拒绝的风险,其中有一种解决方案是在壳版本中注入混淆的代码,防止被苹果检测到内容太过雷同而导致审核被拒绝,本文是针对这个场 ...
- shell编程系列24--shell操作数据库实战之利用shell脚本将文本数据导入到mysql中
shell编程系列24--shell操作数据库实战之利用shell脚本将文本数据导入到mysql中 利用shell脚本将文本数据导入到mysql中 需求1:处理文本中的数据,将文本中的数据插入到mys ...
- Shell脚本学习 - 基本内容以及数据格式
为了捞取日志,自己用python写了一些东西,大致套路就是读取写入文件的操作,放到linux上跑.实际使用时发现要操作的文件有时比较大,直接打开文件找需要的东西可能会有一些效率问题.所以学习一下she ...
- [转帖]Shell脚本中的break continue exit return
Shell脚本中的break continue exit return 转自:http://www.cnblogs.com/guosj/p/4571239.html break结束并退出循环 cont ...
- 如何把rc.local里执行的shell脚本的日志内容放到其他位置
rc.local的日志内容默认是/var/log/boot.log /etc/rc.d/rc.local文件的文件头是#!/bin/sh ,我们把这修改成#!/bin/sh -x,这样系统启动后就会把 ...
- 写个shell脚本搭载jenkins让你的程序部署飞起来
[转载请注明]: 原文出处:https://www.cnblogs.com/jstarseven/p/11399251.html 作者:jstarseven 码字挺辛苦的..... 说明 ...
- shell脚本修改文本中匹配行之前的行的方法
原创文件,欢迎阅读,禁止转载. 例子中是把 finish 前一行的 "yes" 改成 "YES"有一个方法就是利用sed+awk一起来完成. zjk@zjk:~ ...
- shell 脚本中将输出内容赋值给一个变量时的换行问题
for ((i=0; i<4; i++) do ....... done 如果使用 echo $a 输出变量,则变量中的 换行都会被忽略掉,所有内容输出到一行 而使用 echo "$a ...
- shell脚本之删除内容相同的重复文件
#!/bin/bash #!当前文件夹下,删除内容相同的重复文件,只保留重复文件中的一个. ls -lS --time-style=long-iso | awk 'BEGIN{ getline;get ...
随机推荐
- C#基于ScottPlot进行可视化
C#基于ScottPlot进行可视化 前言 上一篇文章跟大家分享了用NumSharp实现简单的线性回归,但是没有进行可视化,可能对拟合的过程没有直观的感受,因此今天跟大家介绍一下使用C#基于Scott ...
- 文心一言 VS 讯飞星火 VS chatgpt (59)-- 算法导论6.4 3题
文心一言 VS 讯飞星火 VS chatgpt (59)-- 算法导论6.4 3题 三.对于一个按升序排列的包含 n 个元素的有序数组 A 来说,HEAPSORT 的时间复杂度是多少?如果 A 是降序 ...
- C#数据结构与算法系列(十七):时间复杂度(下)
1.常见的时间复杂度 常数阶:O(1) 对数阶:O(log2n) 线性阶:O(n) 线性对数阶:O(nlog2n) 平方阶:O(n^2) 立方阶:O(n^3) k次方阶:O(2^n) 常见的算法时间复 ...
- linux_文本处理工具详细介绍
文本处理工具 1. grep工具 grep是行过滤工具:用于根据关键字进行行过滤 语法和选项 语法: # grep [选项] '关键字' 文件名 常见选项: OPTIONS: -i: 不区分大小写 - ...
- 共探AI大模型时代下的挑战与机遇,华为云HCDE与大模型专家面对面
摘要:近日,华为开发者大会2023(cloud)"开发者生态创新发展圆桌会议"在东莞华为溪流背坡村成功举办. 2023年7月8日,华为开发者大会2023(cloud)"开 ...
- 云数据库 GaussDB(for Influx) 解密第十一期:让智能电网中时序数据处理更高效
摘要:GaussDB(for Influx)是一款基于计算存储分离架构,完全兼容 InfluxDB 生态的云原生时序数据库. 本文分享自华为云社区<云数据库 GaussDB(for Influx ...
- Jenkins Pipeline 流水线 - withCredentials 使用
添加凭证 Pipeline script pipeline { agent any stages { stage('withCredentials 使用凭证') { steps { withCrede ...
- CompletableFuture 打桌球的应用
CompletableFuture 使用 @Test public void billiardTest() throws Exception { // 创建点外卖线程: CompletableFutu ...
- 白话文解析LiteFlow的理念是什么?什么时候用该怎么用?干货满满
官网:https://liteflow.cc/ Gitee:https://gitee.com/dromara/liteFlow Github:https://github.com/dromara/l ...
- POJ - 3087:Shuffle'm Up (字符串模拟)
一.内容 题意:给定2个字符串s1,s2,将2个字符串进行重组成S,规则是S2最下面拿一个,S1最下面拿1个,直到所有块都用完. 二.思路 用map记录下S串结果,若以前访问过这个串代表不可能有结果直 ...