Linux(二十九):shell脚本使用grep和awk从文件中读取元素
需求:从配置文件中读取并获取到对应的值,赋值给变量
#!/bin/bash
pwdDir=`pwd`
db_properties=`find $pwdDir -name "db.properties"`
if [ -f "$db_properties" ];then
user=$(cat "$db_properties" | grep "userName" | awk -F '=' '{print $2}')
password=$(cat "$db_properties" | grep "passWord" | awk -F '=' '{print $2}')
#获取url,并从url中获取
url=$(cat "$db_properties" | grep "url" | awk -F '=' '{print $2}')
dbtype=$(echo "$url" | awk -F ':' '{print $2}')
dbhost=$(echo "$url" | awk -F '//' '{print $2}' | awk -F ':' '{print $1}')
port=$(echo "$url" | awk -F '//' '{print $2}' | awk -F ':' '{print $2}' | awk -F '/' '{print $1}')
database=$(echo "$url" | awk -F '//' '{print $2}' | awk -F ':' '{print $2}' | awk -F '/' '{print $2}' | awk -F '?' '{print $1}')
echo $dbtype $dbhost $port $database $user $password
fi
配置文件
#database url driverClass =com.mysql.jdbc.Driver url=jdbc:mysql://10.1.1.143:3306/aoe_auto?useSSL=false&useUnicode=yes&characterEncoding=UTF-8 userName=root passWord=lianshi2020
执行结果:
[root@loaclhost 104_lianshi]# sh test11.sh
mysql 10.1.1.143 3306 aoe_auto root lianshi2020
遇到问题:虽然打印出来了,但是如果赋值到其他里面,会换行
echo "开始执行提取表结构:java -jar $extractorjar --op=extract --db-type=$dbtype --host=$dbhost --port=$port --user=$user --password=$password --database=$database"
解决方法:删除换行,tr -d '\n'
#!/bin/bash
pwdDir=`pwd`
db_properties=`find $pwdDir -name "db.properties"`
if [ -f "$db_properties" ];then
user=$(cat "$db_properties" | grep "userName" | awk -F '=' '{print $2}')
password=$(cat "$db_properties" | grep "passWord" | awk -F '=' '{print $2}')
#获取url,并从url中获取
url=$(cat "$db_properties" | grep "url" | awk -F '=' '{print $2}')
dbtype=$(echo "$url" | awk -F ':' '{print $2}'|tr -d '\n')
dbhost=$(echo "$url" | awk -F '//' '{print $2}' | awk -F ':' '{print $1}' |tr -d '\n')
port=$(echo "$url" | awk -F '//' '{print $2}' | awk -F ':' '{print $2}' | awk -F '/' '{print $1}' |tr -d '\n')
database=$(echo "$url" | awk -F '//' '{print $2}' | awk -F ':' '{print $2}' | awk -F '/' '{print $2}' | awk -F '?' '{print $1}'|tr -d '\n')
echo "开始执行提取表结构:java -jar $extractorjar --op=extract --db-type=$dbtype --host=$dbhost --port=$port --user=$user --password=$password --database=$database"
fi