Skip to main content

API for interacting with paperqa.app

Project description

paperqa-api

Python client for interacting with paperqa app

Usage

Make sure to set the environment variable PQA_API_TOKEN or PQA_API_KEY to your API token.

export PQA_API_TOKEN=pqa-...

To query agent:

import pqapi
response = pqapi.agent_query(
    "Are COVID-19 vaccines effective?"
)

to query with a specific bibliography (collection of papers)

import pqapi
response = pqapi.agent_query(
    "Are COVID-19 vaccines effective?",
    "covid"
)

Templates

You can use templates to batch multiple queries together. A minimal example would be:

The effectiveness of COVID-19 is given below:
{{ "Are COVID-19 vaccines effective?" | pqa}}

Or, more complex examples can use shared bibliographies set by variables names:

{% with bib = "covid" %}
## Info
{{ "Are COVID-19 vaccines effective?" | pqa(bib)}}

## Modality
{{ "Has there been an AAV COVID-19 vaccine?" | pqa(bib)}}
{% endwith %}

You render it via:

pqa-render template.jinja > output.md

Managing bibliographies

To get information about a specific bibliography

import pqapi
response = pqapi.get_bibliography(
    "default"
)
print(response)

You do not need to explicitly create a bibliography, just adding files will create one. To upload files:

import pqapi
files = open("paper.pdf", "rb")
metadata =
    pqapi.UploadMetadata(filename="paper.pdf", citation="Test Citation")

response = pqapi.upload_file(
    "default",
    file
    metadata
)

To delete a bibliography:

import pqapi
response = pqapi.delete_bibliography(
    "default"
)

Development

You can change the server URL endpoint to a local PQA server with

export PQA_URL="http://localhost:8080"

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pqapi-6.3.0.tar.gz (1.5 MB view details)

Uploaded Source

Built Distribution

pqapi-6.3.0-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file pqapi-6.3.0.tar.gz.

File metadata

  • Download URL: pqapi-6.3.0.tar.gz
  • Upload date:
  • Size: 1.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for pqapi-6.3.0.tar.gz
Algorithm Hash digest
SHA256 08d216e873a136548ffe17639ac8239af9aaca7b558afccf9ddb1f375fa3c8a4
MD5 168303b355384bb6dfb3225f8393faa8
BLAKE2b-256 eb93f177451871093000e383db1d55c1f28e55c698f7114e7ca8cb3dee67581a

See more details on using hashes here.

File details

Details for the file pqapi-6.3.0-py3-none-any.whl.

File metadata

  • Download URL: pqapi-6.3.0-py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for pqapi-6.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 75fd521172ea778a9971feb560e31c2fe1a73fb5e59be5e019917bea1d6370cf
MD5 a0fa64db9dc853515c47b9b6408f2f38
BLAKE2b-256 37ce7f4d0b7159ecac4cf7738949e6af0f0df2e6358bd1767ec9c84aba97c9d6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page