shell(10): shell脚本使用grep和awk从文件中读取元素

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宁宁可可

您的鼓励是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值