Create GUI dialogs in one line of code
SQL Data in List Dialogs
SQL command-line utilities can output SQL queries to a Zenity list dialog. Like the earlier CSV examples, the SQL output needs to reformatted to a sequential list. The SQL output from the command-line tools will vary by database; for example, MySQL uses tabs between the fields, whereas SQLite uses a vertical bar (|
).
For my testing, I used an SQLite3 database (someuser.db
) with a table (users
) of fields containing first and last names, age, and job. To output a SELECT
query, I entered:
$ sqlite3 someuser.db "select fname,lname,age,job from users" Brooke|Metcalfe|18|Student Leah|Metcalfe|18|Co-op Pete|Metcalfe|100|Old dude ... Willy|Coyote|99|Evil genius
The SQLite query output can be modified with the tr
command and shown in a Zenity list
dialog (Figure 8):
$ sqlite3 someuser.db "select fname,lname,age,job from users" | tr '|' '\n' | zenity --list --title="My Database" --column="first name" --column="last name" --column=age --column=job
The Zenity list
dialog supports a number of useful options, such as radio buttons and checkboxes. The lists are editable, and the selected fields or rows can be used in further scripting.
Insert SQL Data in a Zenity Form
Zenity forms
allows for the creation of basic data entry dialogs. In about eight lines of Bash code (Listing 3), I created a Zenity form (Figure 9) I can use to insert data into my SQLite users table.
Listing 3
SQL Input Form
01 #!/bin/bash 02 row=$(zenity --forms --title="Create user" --text="Add new user" --add-entry="First Name" --add-entry="Last Name" --add-entry="Age" --add-entry="Job" --separator="','") 03 if [[ -n $row ]] # Some data found 04 then 05 cmd="sqlite3 someuser.db \"INSERT INTO users (Fname,Lname,Age,Job) VALUES ('$row')\"" 06 eval $cmd 07 echo "Added data: '$row'" 08 fi
The OK button will pass the user-entered data as a string, whereas the Cancel button will not pass any data. An if
statement checks to see whether any data has been entered.
The SQL INSERT
statement needs VALUES
to be in the format
("value1","value2,"value3,"value4")
The formatting can be done by setting the Zenity --separator
option to a comma, defined with single quotes within double quotes (line 2).
This example is quite basic, so the next step would be to add data validation.
Final Comments
For simple dialogs, Zenity works amazingly well. I found that as the requirements started to get more complicated, a Python solution appeared to be cleaner and simpler. I was able to control a Raspberry Pi rover in about 20 lines of Bash and Zenity code, but it only took 15 lines of Python and Tkinter code.
There is a Python library (Zenity 2.0) that emulates Zenity, so if you're feeling comfortable with the Zenity dialogs and you don't need complex dialogs, this might be something to consider.
If you are looking for a more complete command-line GUI tool, try YAD [3].
Infos
- Zenity documentation: https://help.gnome.org/users/zenity/3.32/index.html
- Pango markup language: https://developer.gnome.org/pygtk/stable/pango-markup-language.html
- YAD: https://sourceforge.net/projects/yad-dialog/
« Previous 1 2
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Gnome 48 Debuts New Audio Player
To date, the audio player found within the Gnome desktop has been meh at best, but with the upcoming release that all changes.
-
Plasma 6.3 Ready for Public Beta Testing
Plasma 6.3 will ship with KDE Gear 24.12.1 and KDE Frameworks 6.10, along with some new and exciting features.
-
Budgie 10.10 Scheduled for Q1 2025 with a Surprising Desktop Update
If Budgie is your desktop environment of choice, 2025 is going to be a great year for you.
-
Firefox 134 Offers Improvements for Linux Version
Fans of Linux and Firefox rejoice, as there's a new version available that includes some handy updates.
-
Serpent OS Arrives with a New Alpha Release
After months of silence, Ikey Doherty has released a new alpha for his Serpent OS.
-
HashiCorp Cofounder Unveils Ghostty, a Linux Terminal App
Ghostty is a new Linux terminal app that's fast, feature-rich, and offers a platform-native GUI while remaining cross-platform.
-
Fedora Asahi Remix 41 Available for Apple Silicon
If you have an Apple Silicon Mac and you're hoping to install Fedora, you're in luck because the latest release supports the M1 and M2 chips.
-
Systemd Fixes Bug While Facing New Challenger in GNU Shepherd
The systemd developers have fixed a really nasty bug amid the release of the new GNU Shepherd init system.
-
AlmaLinux 10.0 Beta Released
The AlmaLinux OS Foundation has announced the availability of AlmaLinux 10.0 Beta ("Purple Lion") for all supported devices with significant changes.
-
Gnome 47.2 Now Available
Gnome 47.2 is now available for general use but don't expect much in the way of newness, as this is all about improvements and bug fixes.