Chapter 2:
Connect your Python script to Anvil
We’re going to build a simple web UI to display the contents of our database in a table.
Step 2: Add a Data Grid to your app
We’re going to add the interactive table that will contain the data from your external database.
Drag-and-drop a Data Grid into your app:
data:image/s3,"s3://crabby-images/cdc35/cdc35b6d27f299e8fd2dae6e2c78b00659572b97" alt=""
Click on the Data Grid and go to ‘columns’ in the Properties Pane on the right.
Make the Data Grid have two columns:
- Title:
Name
, Key:name
- Title:
Quantity
, Key:quantity
data:image/s3,"s3://crabby-images/b1203/b1203173bab5a65ab4cfdd594f033377286788f8" alt=""
Now your app is ready to display your data.
Step 3: Enable the Uplink
Select the Anvil Uplink in the Gear Menu :
data:image/s3,"s3://crabby-images/ba353/ba3537e361955e9b6208281978e1eaa72399cca1" alt="The Gear Menu with Uplink highlighted."
You’ll see this dialog:
data:image/s3,"s3://crabby-images/73b30/73b3006b483d5a952110742ccec4254d9e247dc9" alt="Uplink dialog showing the Enable Uplink button."
Click the green ‘Enable Uplink’ button. It will display an authentication key that you will use to connect your code to your app.
data:image/s3,"s3://crabby-images/f64e9/f64e94d39e098b4e87b0cacc70b39b966001b3b9" alt="The Uplink dialog with the Uplink enabled and the key displayed."
Step 4: Install the Uplink
Install the Anvil Uplink library in the environment where your script runs:
pip install anvil-uplink
Step 5: Connect your script
At the top of your script, import the Anvil Uplink library:
# Import the Anvil Uplink library
import anvil.server
Below your import statements, run this line to connect to your script to your Anvil app.
Replace <your-uplink-key>
with the key shown in the Uplink dialog in step 3.
# Connect to your Anvil app
anvil.server.connect('<your uplink key>')
Add @anvil.server.callable
to the line above your get_items
function. This makes it possible
to call this function from your Anvil app.
@anvil.server.callable
def get_items():
# ... etc ...
Finally, add this line to the end - it keeps the script alive waiting for connections from your app:
# Wait for connections
anvil.server.wait_forever()
(Also, remove the print(get_items())
from the end of the script)
Your full script should now look like this:
import anvil.server
import psycopg2
anvil.server.connect('<your uplink key>')
conn = psycopg2.connect(
host="18.133.244.120",
user="your_database_id",
password="your_database_password")
conn.set_session(autocommit=True)
cur = conn.cursor()
@anvil.server.callable
def get_items():
cur.execute('SELECT * FROM inventory;')
items = cur.fetchall()
return [
{'id': item[0], 'name': item[1], 'quantity': item[2]}
for item in items
]
anvil.server.wait_forever()
Now we have the Uplink part of the system done:
data:image/s3,"s3://crabby-images/5b45b/5b45b3758c2b7a21b6b40ca83baaffe4435c8c88" alt="We’ve set up the database and proxied to it using the Uplink."
We’ve set up the database and proxied to it using the Uplink.
Step 6: Display the items
Now we’ll call the get_items
function from Anvil and display the result in the Data Grid.
First, run your inventory.py script. It will initialise and wait for connections from your app:
$ python3 inventory.py
Connecting to wss://anvil.works/uplink
Anvil websocket open
Authenticated OK
In your Anvil app, go to the Code View of Form1.
data:image/s3,"s3://crabby-images/836d2/836d28693b991c7b0b4d021cca7bbbb7693b13d6" alt=""
At the end of the __init__
method, add this line:
self.repeating_panel_1.items = anvil.server.call('get_items')
Now run your app. The data from your external Postgres database will be displayed in the table!
data:image/s3,"s3://crabby-images/446ec/446ec9c7164e417506204ee9b0871331c29a5759" alt=""
That’s every element of the system in place!
data:image/s3,"s3://crabby-images/0fe78/0fe7884d8a8893f56f7f929f169e5b9840dd0d72" alt="We’ve implemented the whole system: the database, Uplink script, and web app."
We’ve implemented the whole system: the database, Uplink script, and web app.
Mission complete! That’s the essential task of this tutorial finished. We’ve connected to an external database and displayed its data in a web app.
In the next chapter, we’ll make it interactive: we’ll add, update and remove rows from the table from using the web UI.