Create GUI dialogs in one line of code
Finding a Little Zen

© Lead Image © Martin Capek, 123RF.com
The Zenity command-line utility lets you create simple dialog boxes with your own data or with the output of utilities and applications.
Zenity is a command-line GUI creator that has been around since 2012 and is pre-installed on most versions of Linux, including Raspberry Pis. Zenity isn't designed to be a high-level GUI development tool, but if you just need some basic scripting with dialogs, then Zenity might be a perfect fit.
I was amazed that in one line of Bash code I was able to show:
- stats in a message dialog
- a web page in a dialog
- CSV data or SQL queries in a list dialog
After looking at slightly more complex applications, I found I was able to create:
- a progress bar with dynamic values (about seven lines)
- a form to insert user data into an SQL database (about eight lines)
- a four-button dialog to control a Rasp PI Rover (~20 lines)
In this article, I introduce Zenity with some examples.
Getting Started
The Zenity [1] command-line utility is supported on Linux, macOS, and Windows. Zenity can display calendar, color selector, file selector, form, list, message, notification, progress, scale, and text dialogs.
The Zenity message dialog can be used like a Bash echo statement; for example, to show an information message, enter:
zenity --info --text="Some text" --title="My Title"
Information from command-line tools and utilities can be passed to Zenity. For example, the instantaneous CPU idle time from the top
utility can be parsed and passed to a Zenity dialog (Figure 1):
zenity --info --text=$(top -n 1 | grep %Cpu | awk '{print $8}') --title="CPU Idle Time"
Text font and size can be modified in message dialogs in Pango markup language syntax [2]. Pango is similar to HTML, and the <span>
… </span>
set of tags is typically used to encode font and color definitions (Figure 2):
zenity --warning --text=' HIGH Temperature' --title="HDD Check"
For scripting applications that need to pass more information to users, text-info
dialogs can pass text files and URL links (Figure 3):
zenity --text-info --title="Background Reading" --html --url="https://developer.gnome.org" --checkbox="I read it...and I'm good to go"
For dialogs with OK and Cancel buttons, Zenity returns a
to confirm and a 1
to cancel. Zenity will not process JavaScript on a web page.
Simple dialogs like the info, warning and error dialogs will only have an OK button. All the other dialogs will have Cancel buttons, as well. The button text can be changed with the --ok-label
and the --cancel-label
options. More buttons can be added with the --extra-button
option.
Dynamic Values
A Zenity progress dialog can show dynamic updates with scripts that use subshells. A subshell is configured with parentheses. Step executions within the subshell are paused by sleep statements.
The following code shows a three-step example of a subshell with a Zenity progress dialog (Figure 4):
( echo "33"; echo "# 1/3 done" ; sleep 5; echo "66"; echo "# 2/3 done" ; sleep 5; echo "100";echo "# Finished" ) | zenity --progress --title="3 step test"
When a step outputs a value, the progress bar updates. The text on the progress dialog is changed by outputting a text string that starts with a #
character.
Listing 1 and Figure 5 show an example of current seconds with the progress bar rescaled from 0 to 60.
Listing 1
Scaled Progress Bar
#!/bin/bash # show_seconds.sh - progress dialog to show seconds echo "Press [CTRL+C] to stop..." ( while :; do echo "# $(date +'%S')" # Scale 0-60 to 0-100 echo "$(date +'%S')*100/60" | bc sleep 1 done ) | zenity --progress --title="Show Time in Seconds"
The Bash while
statement lets you show dynamic values continuously until the Cancel button is pressed.
CSV Data in List Dialogs
For simple text files and known datasets, the list
dialog works quite well. The dialog expects the data to be sequential. The following code creates a two-column example (Figure 6) with inline data:
zenity --list --title="2 Column Example" --column="Month" --column="Sales" Jan 100 Feb 95 Mar 77 Apr 110 May 111
To pass a data file (CSV or text) into Zenity, the text needs to be reformatted. The tr
command can replace CSV field separators like commas with a newline (\n) character (Listing 2).
Listing 2
Reformatting Data
$ cat pidata.csv 10:00,12,running 10:20,14,stopped 10:30,13,running $ cat pidata.csv | tr ',' '\n' 10:00 12 running 10:20 14 stopped 10:30 13 running
The output can then be passed to a Zenity list with column headings (Figure 7):
cat pidata.csv | tr ',' '\n' | zenity --list --title="Pi Data" --column="Time" --column="Temp" --column="Pump"
Once you have some Zenity and Bash basics down, you can start doing more advanced operations, such as:
awk -F "\"*,\"*" '{print $3 "\n" $1}' pidata.csv | zenity --list --column="field3" --column="field1"
This one-line example uses Awk to parse specific data (fields 1 and 3) in the CSV file.
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Direct Download
Read full article as PDF:
Price $2.95
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Find SysAdmin Jobs
News
-
KDE Plasma 5.27 Beta is Ready for Testing
The latest beta iteration of the KDE Plasma desktop is now available and includes some important additions and fixes.
-
Netrunner OS 23 Is Now Available
The latest version of this Linux distribution is now based on Debian Bullseye and is ready for installation and finally hits the KDE 5.20 branch of the desktop.
-
New Linux Distribution Built for Gamers
With a Gnome desktop that offers different layouts and a custom kernel, PikaOS is a great option for gamers of all types.
-
System76 Beefs Up Popular Pangolin Laptop
The darling of open-source-powered laptops and desktops will soon drop a new AMD Ryzen 7-powered version of their popular Pangolin laptop.
-
Nobara Project Is a Modified Version of Fedora with User-Friendly Fixes
If you're looking for a version of Fedora that includes third-party and proprietary packages, look no further than the Nobara Project.
-
Gnome 44 Now Has a Release Date
Gnome 44 will be officially released on March 22, 2023.
-
Nitrux 2.6 Available with Kernel 6.1 and a Major Change
The developers of Nitrux have officially released version 2.6 of their Linux distribution with plenty of new features to excite users.
-
Vanilla OS Initial Release Is Now Available
A stock GNOME experience with on-demand immutability finally sees its first production release.
-
Critical Linux Vulnerability Found to Impact SMB Servers
A Linux vulnerability with a CVSS score of 10 has been found to affect SMB servers and can lead to remote code execution.
-
Linux Mint 21.1 Now Available with Plenty of Look and Feel Changes
Vera has arrived and although it is still using kernel 5.15, there are plenty of improvements sure to please everyone.