{"library":"python-liquid","title":"Python Liquid","description":"Python Liquid is a Python engine for Liquid, the safe, customer-facing template language, currently at version 2.1.0. It closely follows Shopify/Liquid's design and test suite, providing a robust and secure templating solution for web applications. While there isn't a fixed release cadence, the project is actively maintained with regular updates.","language":"python","status":"active","last_verified":"Fri May 15","install":{"commands":["pip install python-liquid"],"cli":{"name":"liquid","version":"sh: 1: liquid: not found"}},"imports":["from liquid import render","from liquid import parse","from liquid import Template","from liquid import Environment","from liquid import FileSystemLoader"],"auth":{"required":false,"env_vars":[]},"quickstart":{"code":"from liquid import Environment, FileSystemLoader\nimport os\n\n# For a simple template string, use render() or parse():\n# from liquid import render\n# print(render(\"Hello, {{ you }}!\", you=\"World\"))\n\n# For more complex applications, an Environment is recommended.\n# This example assumes a 'templates' directory with 'index.liquid'.\n\n# Create a dummy templates directory and file for demonstration\nos.makedirs(\"templates\", exist_ok=True)\nwith open(\"templates/index.liquid\", \"w\") as f:\n    f.write(\"Hello, {{ name }}! From {{ app_name }}. Today is {{ date | date: '%Y-%m-%d' }}.\")\n\nenv = Environment(\n    loader=FileSystemLoader(\"templates/\"),\n    globals={\n        \"app_name\": os.environ.get('LIQUID_APP_NAME', 'Default App') # Example with env var\n    }\n)\n\ntemplate = env.get_template(\"index.liquid\")\noutput = template.render(name=\"Liquid User\", date=\"2026-04-11\")\nprint(output)\n\n# Clean up dummy files/directory\nos.remove(\"templates/index.liquid\")\nos.rmdir(\"templates\")","lang":"python","description":"The simplest way to render a template string is using the package-level `render()` function. For applications requiring configuration, template loading from files, or better performance, it's recommended to configure an `Environment` instance. This example demonstrates using `Environment` with a `FileSystemLoader` to render a template from a file, passing variables and accessing globals.","tag":null,"tag_description":null,"last_tested":null,"results":[]},"compatibility":{"tag":null,"tag_description":null,"last_tested":"2026-05-15","installed_version":"2.2.0","pypi_latest":"2.2.0","is_stale":false,"summary":{"python_range":"3.10–3.9","success_rate":100,"avg_install_s":2.5,"avg_import_s":0.66,"wheel_type":"wheel"},"results":[{"runtime":"python:3.10-alpine","python_version":"3.10","os_libc":"alpine (musl)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":null,"import_time_s":0.43,"mem_mb":12.1,"disk_size":"55.9M"},{"runtime":"python:3.10-slim","python_version":"3.10","os_libc":"slim (glibc)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":2.5,"import_time_s":0.35,"mem_mb":12.2,"disk_size":"56M"},{"runtime":"python:3.11-alpine","python_version":"3.11","os_libc":"alpine (musl)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":null,"import_time_s":0.83,"mem_mb":13.3,"disk_size":"58.4M"},{"runtime":"python:3.11-slim","python_version":"3.11","os_libc":"slim (glibc)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":2.5,"import_time_s":0.74,"mem_mb":13.3,"disk_size":"59M"},{"runtime":"python:3.12-alpine","python_version":"3.12","os_libc":"alpine (musl)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":null,"import_time_s":0.84,"mem_mb":13.3,"disk_size":"50.1M"},{"runtime":"python:3.12-slim","python_version":"3.12","os_libc":"slim (glibc)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":2.3,"import_time_s":0.89,"mem_mb":13.4,"disk_size":"51M"},{"runtime":"python:3.13-alpine","python_version":"3.13","os_libc":"alpine (musl)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":null,"import_time_s":0.9,"mem_mb":13.7,"disk_size":"49.9M"},{"runtime":"python:3.13-slim","python_version":"3.13","os_libc":"slim (glibc)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":2.4,"import_time_s":0.85,"mem_mb":13.8,"disk_size":"50M"},{"runtime":"python:3.9-alpine","python_version":"3.9","os_libc":"alpine (musl)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":null,"import_time_s":0.4,"mem_mb":12.2,"disk_size":"55.4M"},{"runtime":"python:3.9-slim","python_version":"3.9","os_libc":"slim (glibc)","variant":"python-liquid","exit_code":0,"wheel_type":"wheel","failure_reason":null,"import_side_effects":"clean","install_time_s":2.9,"import_time_s":0.36,"mem_mb":12.3,"disk_size":"56M"}]}}