在Shell脚本中使用窗口
来源:互联网 发布:妲露拉.莱莉 知乎 编辑:程序博客网 时间:2024/06/08 10:18
一般基于Shell的脚步交互看起来都不是很友好,有一个库:dialog可以帮我们解决这个问题,它能在文本环境中用ANSI转义控制字符来创建标准的窗口对话框,有的Linux发行版系统没有安装,可以直接执行sudo apt-get install dialog安装即可。目前,dialog包支持如下窗口部件(widget):
calender提供选择日期的日历checklist显示多个选项(其中每个选项都能打开或关闭)from构建一个表单(用标签和文本字段来填充)fselect提供一个文件选择窗口来浏览选择文件gauge显示完成的百分比进度条infobox显示一条消息,但不用等待回应inputbox提供一个输入文本用的文本菜单inputmenu提供一个可编辑的菜单menu显示可选择的一系列选项msgbox显示一条消息,并要求用户选择OK按钮pause显示一个进度条来显示特定暂定时间的状态passwordbox显示一个文本框来输入文本,但会隐藏输入的文本passwordform显示一个带标签和隐藏文本输入的菜单radiolist提供一组菜单选项,但只能选择其中一个tailbox用tail命令在滚动窗口中显示文件的内容tailboxbg与tailbox一样,但是在后台模式中运行textbox在滚动窗口中显示文件的内容timebox提供一个选择小时、分钟和秒数的窗口yesno提供一条简单的带yes和no按钮的消息使用指定窗口部件很简单,只需在dialog命令加参数--跟部件名称即可: dialog --{widget_name} {widget_parameters}
每个部件都提供两种格式的输出:
1. 使用STDERR
2. 使用退出状态码,它决定了用户选择的按钮,如选择了YES或OK按钮,dialog命令会返回退出状态码0,如选择了Cancle或NO按钮,则返回1,我们可以在下一条命令使用$?变量来查看dialog部件种具体用户选择了哪个按钮。另外,如果部件返回了用户输入的数据,dialog命令会将数据发送到STDERR,当然,可以重定向到文件,然后提供后面命令从文件中读取: dialog --inputbox "Enter you choice:" 10 202>input.txt
实例演示
下面用一个简单的数据库管理功能的脚本来演示:
#!/bin/bash# A shell script for manage mysql server# Author: LinJK# Date: 10/15/2017temp1=`mktemp -t tmp.XXXXXX`temp_result=`mktemp -t tmp_re.XXXXXX`db_user=xxxxdb_port=xxxxdb_host=xxxxdate_now=$(date +%Y%m%d%H%M)function get_mysql_pwd { dialog --insecure --passwordbox "Enter mysql password:" 10 30 2> $temp_result}function get_mysql_dbs { mysql -u${db_user} -P${db_port} -p${db_pwd} -h${db_host} -e "show databases;" > $temp_result}function show_all_databases { get_mysql_pwd db_pwd=`cat $temp_result` get_mysql_dbs if [ $? -eq 1 ] then dialog --msgbox "Error password" 10 30 else sed -n '2,$p' $temp_result > $temp1 dialog --title `sed -n 1p $temp_result` --textbox $temp1 20 60 fi}function dump_selected_database { get_mysql_pwd db_pwd=`cat $temp_result` get_mysql_dbs sed -n '2,$p' $temp_result > $temp1 checklist_cmd="" while read line do checklist_cmd=$checklist_cmd" "$line" "$line" "$line done < $temp1 # selected db to dump dialog --checklist "Databases" 20 60 10 $checklist_cmd 2> $temp1 arr_sel=`cat $temp1` OLD_IFS="$IFS" IFS=" " arr=($arr_sel) IFS="$OLD_IFS" for db_name in ${arr[@]} do mysqldump -u${db_user} -P${db_port} -p${db_pwd} -h${db_host} --hex-blob --single-transaction -B ${db_name}|gzip > ./${db_name}_${date_now}.sql.gz done}while [ 1 ]do dialog --menu "MySQL Management - LinJK_Ali" 20 50 10 \ 1 "Show all databases" \ 2 "Dump selected database" \ 0 "Exit" \ 2> $temp1 if [ $? -eq 1 ] then break fi selection=`cat $temp1` case $selection in 1) show_all_databases ;; 2) dump_selected_database ;; 0) dialog --title "Tips" --yesno "Sure to exit?" 10 30 if [ $? -eq 0 ] then break fi ;; *) dialog --title "Error" --msgbox "Invalid selection." 10 30 esacdonerm -rf $temp1 2> /dev/nullrm -rf $temp_result 2> /dev/null
这里为了简单,就不具体管理数据库了,就显示磁盘信息吧,后面再完善(2017-10-15 10:03:28完善,可以正常备份、查看数据库)。运行效果如下:
首页:
光标现在在选项1,我们按回车键选择(也可以鼠标点击选择)后,窗口如下:
使用流程就这样,很简单上手,要了解更多,执行"man dialog"了解详细参数情况。
阅读全文
0 0
- 在Shell脚本中使用窗口
- 在shell脚本中使用ftp telnet
- 在shell脚本中使用sudo
- 8、在Shell脚本中使用函数
- 在shell脚本中使用alias
- 在Android.mk编译脚本中使用shell bash命令
- 在shell脚本中,如何写使用for循环
- 在shell脚本中,如何写使用for循环
- 在C程序中使用popen调用shell脚本程序
- 在shell脚本中使用getopts处理参数
- 在gawk中 使用shell脚本中的变量
- 在shell脚本中使用expect实现scp传输问题
- 在shell脚本中使用ls命令的注意事项
- 在shell脚本中调用另一个脚本
- Shell-alias在Shell脚本中的使用
- shell脚本中使用MySQL
- shell脚本中循环使用
- 在shell脚本中使用另一个脚本中声明的变量
- window如何读取配置文件连接oracle数据库
- 学习记录 11——CSS-文字排版(17/10/15 于成都)
- 实验二 Linux用户管理
- 阿里巴巴Java开发规约插件全球首发
- java基础------认识java
- 在Shell脚本中使用窗口
- Java常用方法
- GDB
- java基础知识---(类的声明之人类)
- HDOJ 1014 Uniform Generator
- JS字符串截取函数slice(),substring(),substr()的区别
- 关于Android中的各种Dialog
- Android logger日志和ButterKnife使用
- 对象的建立和释放