Test in a live environment
Test in production without watermarks.
Works wherever you need it to.
The sqlite3 module in Python offers a way to interact with SQLite databases. It is part of the Python Standard Library, so you don't need to install anything extra to use it. Let's explore its features and see some code examples. Later in this article, we will explore IronPDF, a PDF generation library developed by Iron Software.
SQLite is a lightweight, disk-based database that doesn't require a separate database server process. The sqlite3 module provides an SQL interface-compliant environment to interact with an existing database or newly created database seamlessly. The module enforces the DB-API 2.0 specification described by PEP 2491.
Here's a simple example and multiple SQL statements to get you started with sqlite3.
First, you'll need to connect to your SQLite database. If the database file is missing, it will be generated:
import sqlite3
# Connect to the database (or create it if it doesn't exist)
conn = sqlite3.connect('example.db')
# Create a cursor object
cur = conn.cursor()
Use the CREATE TABLE SQL statement to create a new data table:
# Create a table using sql statements like below
cur.execute('''
CREATE TABLE IF NOT EXISTS users (
id INTEGER PRIMARY KEY,
name TEXT NOT NULL,
age INTEGER
)
''')
Here's how to insert data into the database table:
# Insert data into the table
cur.execute('''
INSERT INTO users (name, age) VALUES (?, ?)
''', ('Alice', 30))
# Commit the transaction with connection object
conn.commit()
You can run SQL commands and fetch results from the database table:
# Query the database
cur.execute('SELECT * FROM users')
# Fetch all results
rows = cur.fetchall()
# Print the results
for row in rows:
print(row)
To update existing data in the table:
# Update data in the table
cur.execute('''
UPDATE users SET age = ? WHERE name = ?
''', (31, 'Alice'))
# Commit the transaction
conn.commit()
To delete data from the database rows where the name is Alice:
# Delete data from the table
cur.execute('''
DELETE FROM users WHERE name = ?
''', ('Alice',))
# Commit the transaction
conn.commit()
Remember to close both the cursor and the connection when you are finished:
# Close the cursor and connection
cur.close()
conn.close()
You can use context managers to handle closing the connection automatically:
with sqlite3.connect('example.db') as conn:
cur = conn.cursor()
cur.execute('SELECT * FROM users')
rows = cur.fetchall()
for row in rows:
print(row)
SQLite supports transactions, and you can use BEGIN, COMMIT, and ROLLBACK to manage them:
try:
conn.execute('BEGIN')
cur.execute('INSERT INTO users (name, age) VALUES (?, ?)', ('Bob', 25))
conn.commit()
except sqlite3.Error as e:
conn.rollback()
print(f"An error occurred: {e}")
IronPDF is a powerful Python library designed to create, edit, and sign PDFs using HTML, CSS, images, and JavaScript. It offers commercial-grade performance with a low memory footprint. Key features include:
HTML to PDF Conversion:
Convert HTML files, HTML strings, and URLs to PDFs. For example, render a webpage as a PDF using the Chrome PDF renderer.
Cross-Platform Support:
Compatible with various .NET platforms, including .NET Core, .NET Standard, and .NET Framework. It supports Windows, Linux, and macOS.
Editing and Signing:
Set properties, add security with passwords and permissions, and apply digital signatures to your PDFs.
Page Templates and Settings:
Customize PDFs with headers, footers, page numbers, and adjustable margins.It supports responsive layouts and custom paper sizes.
Standards Compliance:
It complies with PDF standards like PDF/A and PDF/UA, supports UTF-8 character encoding, and manages assets such as images, CSS, and fonts.
import sqlite3
from ironpdf import *
# Apply your license key
License.LicenseKey = "key"
# Connect to the sqlite database file (or create it if it doesn't exist)
conn = sqlite3.connect('example.db')
# Create a cursor object for database connection
cur = conn.cursor()
# Create a table sql command
cur.execute('''
CREATE TABLE IF NOT EXISTS users (
id INTEGER PRIMARY KEY,
name TEXT NOT NULL,
age INTEGER
)
''')
# Insert data into the table
cur.execute('''
INSERT INTO users (name, age) VALUES (?, ?)
''', ('IronUser1', 30))
cur.execute('''
INSERT INTO users (name, age) VALUES (?, ?)
''', ('IronUser2', 31))
cur.execute('''
INSERT INTO users (name, age) VALUES (?, ?)
''', ('IronUser3', 25))
cur.execute('''
INSERT INTO users (name, age) VALUES (?, ?)
''', ('IronUser4', 28))
# Commit the transaction with connection object
conn.commit()
# Query the database
cur.execute('SELECT * FROM users')
# Fetch all results
rows = cur.fetchall()
# Print the results
for row in rows:
print(row)
# Update data in the table
cur.execute('''
UPDATE users SET age = ? WHERE name = ?
''', (31, 'Alice'))
# Commit the transaction
conn.commit()
# Delete data from the table
cur.execute('''
DELETE FROM users WHERE name = ?
''', ('IronUser1',))
# Commit the transaction
conn.commit()
renderer = ChromePdfRenderer()
# Create a PDF from a HTML string using Python
content = "<h1>Awesome Iron PDF with Sqlite3</h1>"
content += "<p>table data</p>"
for row in rows:
print(row)
content += "<p>"+str(row)+"</p>"
# Close the cursor and connection
cur.close()
conn.close()
pdf = renderer.RenderHtmlAsPdf(content)
# Export to a file or Stream
pdf.SaveAs("DemoSqlite3.pdf")
This Python program demonstrates how to use the SQLite library to create a database, insert data into it, perform queries, update records, delete records, and finally generate a PDF document using IronPDF.
This script demonstrates a complete workflow from database setup to data manipulation and PDF generation using Python's SQLite3 and IronPDF libraries.
IronPDF runs on the license key. IronPDF for Python offers a free trial license key to allow users to test its extensive features before purchase.
Place the License Key here:
import {IronPdfGlobalConfig, PdfDocument} from "@ironsoftware/ironpdf";
// Apply your IronPDF license key
IronPdfGlobalConfig.getConfig().licenseKey = "Add Your key here";
The sqlite3 module is a powerful and easy-to-use tool for working with SQLite databases in Python. Its integration into the Python Standard Library makes simple and complex database operations convenient. The IronPDF. Afterward, the license starts at $749 and upwards.
9 .NET API products for your office documents