linux shell 脚本中创建对话框 (whiptail 工具)

在终端环境下安装新的软件时,可以经常看到信息对话框弹出。对话框的类型有密码箱,检查表,菜单,等等。 whiptail 可以在 shell 脚本中创建基于终端的对话框,消息框的过程,类似于 Zenity 或 xdialog GUI 脚本代码。


whiptail 语法

whiptail  [  --title  title  ]  [ --backtitle backtitle ] [ --clear ] [ --default-item string ] [ --defaultno ] [  --fb  ]  [  --nocancel  ]  [ --yes-button  text ] [ --no-button text ] [ --ok-button text ] [ --can‐cel-button text ] [ --noitem [ ] --output-fd fd ] [ --separate-output ] [ --scrolltext ] [ --topleft ] box-options

选项说明

--clear
       The screen will be cleared to the screen attribute on exit.  This doesn't work in an  xterm  (and  descendants)  if  alternate
       screen switching is enabled, because in that case slang writes to (and clears) an alternate screen.

--defaultno
       The dialog box will open with the cursor over the No button.

--default-item string
       Set  the default item in a menu box.  Normally the first item in the box is the default.

--fb   Use full buttons. (By default, whiptail uses compact buttons).

--nocancel
       The dialog box won't have a Cancel button.

--yes-button text
       Set the text of the Yes button.

--no-button text
       Set the text of the No button.

--ok-button text
       Set the text of the Ok button.

--cancel-button text
       Set the text of the Cancel button.

--noitem
       The menu, checklist and radiolist widgets will display tags only, not the item strings. The menu widget still needs some items
       specified, but checklist and radiolist expect only tag and status.

--separate-output
       For checklist widgets, output result one line at a time, with no quoting.  This facilitates parsing by another program.

--output-fd fd
       Direct output to the given file descriptor.  Most whiptail scripts write to standard error, but  error   messages   may   also
       be written there, depending on your script.

--title title
       Specifies a title string to be displayed at the top of the dialog box.

--backtitle backtitle
       Specifies a backtitle string to be displayed on the backdrop, at the top of the screen.

--scrolltext
       Force the display of a vertical scrollbar.

--topleft
       Put window in top-left corner.

对话框选项说明
--yesno text height width
       A  yes/no  dialog box of size height rows by width columns will be displayed. The string specified by text is displayed inside
       the dialog box. If this string is too long to be fit in one line, it will be automatically  divided  into  multiple  lines  at
       appropriate  places.  The text string may also contain the sub-string "\n" or newline characters `\n' to control line breaking
       explicitly.  This dialog box is useful for asking questions that require the user to answer either yes or no.  The dialog  box
       has a Yes button and a No button, in which the user can switch between by pressing the TAB key.

--msgbox text height width
       A  message  box is very similar to a yes/no box.  The only difference between a message box and a yes/no box is that a message
       box has only a single OK button. You can use this dialog box to display any message you like.  After reading the message,  the
       user can press the ENTER key so that whiptail will exit and the calling shell script can continue its operation.

--infobox text height width
       An info box is basically a message box.  However, in this case, whiptail will exit immediately after displaying the message to
       the user. The screen is not cleared when whiptail exits, so that the message will remain on the screen until the calling shell
       script  clears it later. This is useful when you want to inform the user that some operations are carrying on that may require
       some time to finish.

--inputbox text height width [init]
       An input box is useful when you want to ask questions that require the user to input a string as the answer. If init  is  sup‐
       plied  it  is  used to initialize the input string.  When inputing the string, the BACKSPACE key can be used to correct typing
       errors. If the input string is longer than the width of the dialog box, the input field will be scrolled. On exit,  the  input
       string will be printed on stderr.

--passwordbox text height width [init]
       A password box is similar to an input box, except the text the user enters is not displayed. This is useful when prompting for
       passwords or other sensitive information. Be aware that if anything is passed in "init", it will be visible  in  the  system's
       process  table  to casual snoopers. Also, it is very confusing to the user to provide them with a default password they cannot
       see. For these reasons, using "init" is highly discouraged.

--textbox file height width
       A text box lets you display the contents of a text file in a dialog box. It is like a simple text file viewer.  The  user  can
       move  through  the  file  by using the UP/DOWN, PGUP/PGDN and HOME/END keys available on most keyboards.  If the lines are too
       long to be displayed in the box, the LEFT/RIGHT keys can be used to scroll the text region horizontally. For more convenience,
       forward and backward searching functions are also provided.

--menu text height width menu-height [ tag item ] ...
       As  its  name suggests, a menu box is a dialog box that can be used to present a list of choices in the form of a menu for the
       user to choose. Each menu entry consists of a tag string and an item string. The tag gives the entry a name to distinguish  it
       from the other entries in the menu. The item is a short description of the option that the entry represents. The user can move
       between the menu entries by pressing the UP/DOWN keys, the first letter of the tag as a hot-key. There are menu-height entries
       displayed in the menu at one time, but the menu will be scrolled if there are more entries than that. When whiptail exits, the
       tag of the chosen menu entry will be printed on stderr.

--checklist text height width list-height [ tag item status ] ...
       A checklist box is similar to a menu box in that there are multiple entries presented in the form of a menu.  You  can  select
       and  deselect  items  using the SPACE key.  The initial on/off state of each entry is specified by status.  On exit, a list of
       the tag strings of those entries that are turned on will be printed on stderr.


--radiolist text height width list-height  [ tag item status ] ...
       A radiolist box is similar to a menu box.  The only difference is that you can indicate which entry is currently selected,  by
       setting its status to on.


--gauge text height width percent
       A  gauge  box  displays a meter along the bottom of the box.  The meter indicates a percentage.  New percentages are read from
       standard input, one integer per line.  The meter is updated to reflect each new percentage.  If stdin is XXX, then  subsequent
       lines up to another XXX are used for a new prompt.  The gauge exits when EOF is reached on stdin.

whiptail用法示例:

  • 创建一个消息框(一个消息框中显示一个确认按钮。)
    # 语法
    # whiptail --title title_text --msbox text height width
    
    # 示例
    #!/bin/sh
    whiptail --title "Test Message Box" --msgbox "Create a message box with whiptail. Choose Ok to continue." 10 60

  • 创建一个 yes/no 对话框 (用户选择 yes 或 no 按键的对话框)
    # 语法
    # whiptail --title title_text --yesno text height width
    
    # 示例 
    #!/bin/sh
    if(whiptail --title "Test Yse/No Box" --yesno "Choose between Yes and No." 10 60)
    then
    	echo "You chose Yes. Exit status was $?."
    else
    	echo "You chose No. Exit status was $?."
    fi
    
    # 或者写成 “--yes-button” “--no-button” 选项
    #!/bin/bash
    if (whiptail --title "Test Yes/No Box" --yes-button "Skittles" --no-button "M&M's"  --yesno "Which do you like better?" 10 60) then
        echo "You chose Skittles Exit status was $?."
    else
        echo "You chose M&M's. Exit status was $?."
    fi

  • 创建一个表单输入框 (如果用户想输入任意的文本,可以使用一个输入框)
    # 语法
    # whiptail --title title_text --inputbox text height width [init]  3>&1 1>&2 2>&3
    # 实例:
    #!/bin/bash
    PET=$(whiptail --title "Test Free-form Input Box" --inputbox "What is your pet's name?" 10 60 Wigglebutt 3>&1 1>&2 2>&3)
     
    exitstatus=$?
    if [ $exitstatus = 0 ]; then
        echo "Your pet name is:" $PET
    else
        echo "You chose Cancel."
    fi

  • 创建一个密码框(当用户需要输入敏感信息时使用密码框)
    当用户需要输入敏感信息时使用密码框
    # 语法
    # whiptail --title title_text --passwordbox text height width [init]	
    # 实例:
    #!/bin/bash
    PET=$(whiptail --title "Test Free-form Input Box" --inputbox "What is your pet's name?" 10 60 Wigglebutt 3>&1 1>&2 2>&3)
     
    exitstatus=$?
    if [ $exitstatus = 0 ]; then
        echo "Your pet name is:" $PET
    else
        echo "You chose Cancel."
    fi	

  • 创建一个菜单栏(想让用户选择一个任意数量的选择时,使用菜单框)
    # 语法 
    # whiptail --title title_text --menu text height width menu-height [ tag item ]
    
    # 实例:
    #!/bin/bash
    OPTION=$(whiptail --title "Test Menu Dialog" --menu "Choose your option" 15 60 4 \
    "1" "Grilled Spicy Sausage" \
    "2" "Grilled Halloumi Cheese" \
    "3" "Charcoaled Chicken Wings" \
    "4" "Fried Aubergine"  3>&1 1>&2 2>&3)
     
    exitstatus=$?
    if [ $exitstatus = 0 ]; then
        echo "Your chosen option:" $OPTION
    else
        echo "You chose Cancel."
    fi

  • 创建一个表对话框(多选一。一个表中有多个选项清单,只允许选择一个)
    # 语法
    # whiptail –-title title_text -–radiolist text height width list-height  [ tag item status ] ...
    
    # 实例:
    #!/bin/bash
    DISTROS=$(whiptail --title "Test Checklist Dialog" --radiolist \
    "What is the Linux distro of your choice?" 15 60 4 \
    "debian" "Venerable Debian" ON \
    "ubuntu" "Popular Ubuntu" OFF \
    "centos" "Stable CentOS" OFF \
    "mint" "Rising Star Mint" OFF 3>&1 1>&2 2>&3)
     
    exitstatus=$?
    if [ $exitstatus = 0 ]; then
        echo "The chosen distro is:" $DISTROS
    else
        echo "You chose Cancel."
    fi

  • 创建一个表对话框(可多选,一个列表中多个选项的清单对话框是有用的。)
    创建一个表对话框(可多选)
    一个列表中多个选项的清单对话框是有用的。(可多选)
    # 语法:
    # whiptail --title title_text --checklist text height width list-height [ tag item status ] ...
    
    # 实例:
    #!/bin/bash
    DISTROS=$(whiptail --title "Test Checklist Dialog" --checklist \
    "Choose preferred Linux distros" 15 60 4 \
    "debian" "Venerable Debian" ON \
    "ubuntu" "Popular Ubuntu" OFF \
    "centos" "Stable CentOS" ON \
    "mint" "Rising Star Mint" OFF 3>&1 1>&2 2>&3)
     
    exitstatus=$?
    if [ $exitstatus = 0 ]; then
        echo "Your favorite distros are:" $DISTROS
    else
        echo "You chose Cancel."
    fi

  • 创建一个进度条(进度条是一个用户友好的对话框。whiptail从标准输入读取一个百分数(0~100),显示一个表内相应的计数。)
    # 语法:
    # whiptail --title title_text --gauge text height width percent
    
    # 实例:
    #!/bin/bash
    {
        for ((i = 0 ; i <= 100 ; i+=20)); do
            sleep 1
            echo $i
        done
    } | whiptail --gauge "Please wait while installing" 6 60 0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值