PatentSearch API Reference
Introduction
The PatentsView PatentSearch API is intended to inspire the exploration and enhanced understanding of US intellectual property (IP) and innovation systems. The database driving the API is regularly updated and integrates the best available tools for inventor disambiguation and data quality control. We hope researchers and developers alike will explore the API to discover people and companies and to visualize trends and patterns across the US innovation landscape.
Throughout this document, whenever the {}
syntax is used, users are expected to replace it with valid values.
Authentication
API Keys
The PatentSearch API uses API Keys to authenticate requests but there are no specific authorization enforced. i.e. if you have an API Key you can access all publicly available endpoints.
-
All API requests must include the header
X-Api-Key: {your_key}
infoCurrently, the API Keys do not expire but this may change in the future. If this changes, we will update the documentation here as well as communicate changes with the users via the patentsview website and the mailing list.
tipIf users previously used a browser to run API queries, due to the API key enforcement users will not be able use the same workflow. Alternatively either a standalone applications (such as Postman) or browser extension (such as RESTED in Firefox/Chrome) can be used to send one-off queries.
Usage Limits
Each API Key is allowed 45 requests/minute. If you exceed this limit, your API requests will fail. See HTTP Response Code for more details
Request an API Key
You can obtain an API key by submitting a request via PatentsView Help Center. Each user is allowed only one API Key. If you lose your API key, please request a new one with same email address and name.
Please do not request/use multiple keys at the same time. If you do, your access may be revoked.
API Request
Structure of Request
An API request is made of 4 components:
- API Key (Discussed above)
- The requested endpoint (See Endpoints specifications)
- Request method
- Request parameters
Request Method
All PatentSearch API endpoints support two methods: GET and POST. Both GET and POST use/require the same set of parameters.
The PatentsView PatentSearch API endpoints don't allow users to submit data to our databases. The POST method is another mechanism for posting query parameters, not for adding new records.
Request Parameters
There are 4 parameters that can be provided in a request. Each of the components is fully specified in the API Query Language section. Briefly:
- Query String(
q
) - used to filter data - Field list (
f
) - used to specify fields to return - Sorting (
s
) - used to specify ordering - Options (
o
) - used to specify additional options and pagination
Defaults
Each API endpoint is configured with appropriate defaults for f
, s
and o
parameters. When the user don't include
one or more these parameters, the defaults will be used. q
parameter is without defaults and is mandatory.
- By default, the API will return 100 records. This can be increased up to 1,000. See Pagination section.
- The default for
s
parameter is to sort by the "ID" field of that particular endpoint in ascending order E.g.patent_id
is the default sort field for/patent
endpoint
API Response
HTTP Response Codes
Response Code | Description | Potential Resolution | ||
---|---|---|---|---|
200 | Request Successfully Completed | |||
400 | Request Invalid | Review X-Status-Reason and X-Status-Reason-Code response headers for more details | ||
404 | Resource not found | Verify the endpoint URL is correct. If using "GET" resource locator, verify the supplied ID is valid | ||
429 | Too many requests | Your application has exceeded the usage limits. Use Retry-After response header to identify wait duration before making the next request | ||
500 | Server Error | This is typically an error on our servers. Check the Service Status page and/or submit a support request |
Response Structure
Every API response will have the following structure:
error
: a boolean flag indicating if the request succeeded or failedcount
: total number of records returned in this responsetotal_hits
: total number of records that matched the current query...
: The final and the main data component on the response will be based on the endpoint used. (See individual endpoints for details)
{
"error": "boolean",
"count": "integer",
"total_hits": "integer",
...
}
API Query Language
Query String (q
)
Query String Format
The query string is always a single JSON object: {}
, with properties and contained objects that determine the
criteria for the query.
Note: To aid in understanding the structure of the queries below and while creating your own, it is helpful to use JSON validators and visual parsers, like http://www.jsoneditoronline.org/ and http://jsonlint.com/.
Syntax
q={criterion}
criterion
pair
"_eq" : {simple_pair}
"_neq" : {simple_pair}
"_gt" : {simple_pair}
"_gte" : {simple_pair}
"_lt" : {simple_pair}
"_lte" : {simple_pair}
"_begins" : {simple_pair}
"_contains" : {simple_pair}
"_text_all" : {simple_pair}
"_text_any" : {simple_pair}
"_text_phrase" : {simple_pair}
"_not" : {criterion}
"_and" : [{criterion}, ...]
"_or" : [{criterion}, ...]
pair
simple_pair
"field" : [value, ...]
simple_pair
"field" : value
When working with text data fields, wherever possible, we recommend using _text*
operators over the _contains
and _begins
operator. The text operators treat these fields as full text data and hence are more performant. The "full text" fields are identified in the API Endpoint specification with the value "text" for the data type.
Single Criterion (Equals operator)
The basic criterion, which checks for equality, has the format: {<field>:<value>}
, where <field>
is the name of a
database field and <value>
is the value the field will be compared to for equality (Each API Endpoint section contains
a list of the data fields that can be selected for inclusion in output datasets)
For example, this query string will return the patent with the patent number of 7861317:
https://search.patentsview.org/api/v1/patent/?q={"patent_id":"7861317"}
Comparison Operators
Comparison operators can be used to compare a field to a value using comparators other than equality. The available comparison operators are:
- Integer, float, date, and string:
_eq
— equal to_neq
— not equal to_gt
— greater than_gte
— greater than or equal to_lt
— less than_lte
— less than or equal to
- String:
_begins
— the string begins with the value string_contains
— the string contains the value string
- Full text:
_text_all
— the text contains all the words in the value string_text_any
— the text contains any of the words in the value string_text_phrase
— the text contains the exact phrase of the value string
To specify a comparison operator for a criterion, nest the element containing the criterion inside an element that uses the comparison operator.
For example, this query string will return all patents that have a grant date on or after January 9, 2007:
https://search.patentsview.org/api/v1/patent/?q={"_gte":{"patent_date":"2007-01-09"}}
The query string q={"_eq":{"patent_date":"2007-01-09"}}
is functionally equivalent to q={"patent_date":"2007-01-09"}
Negation
Negation does the opposite of the specified comparison. To specify the negation operator for a criterion, nest the element containing the criterion inside an element that uses the negation operator: _not.
For example, this query string will return all patents that are not design patents:
https://search.patentsview.org/api/v1/patents/q={"_not":{"patent_type":"design"}}
Value Arrays
If the value of a criterion is an array, then the query will accept a match of any one of the array values.
For example, this query will return all patents that have "Whitney" or "Hopper" as an inventor:
https://search.patentsview.org/api/v1/patents/q={"inventors.inventor_name_last":["Whitney","Hopper"]}
Join (Conjunction) Operators
Multiple criteria can be added to a query using a join operator (_and
, _or
) and putting the criteria in an array
using
square brackets ("[" and "]").
The following has multiple criteria, and will return patents that have "Whitney" as an inventor and a grant date of October 6, 1981:
https://search.patentsview.org/api/v1/patents/query?q={"_and":[{"inventors.inventor_name_last":"Whitney"},{"patent_date":"1981-10-06"}]}
Complex Combinations
These elements, criteria, arrays, and operators can be combined to define robust queries. A few examples:
Patents with a grant date in 2007:
https://search.patentsview.org/api/v1/patents/q={"_and":[{"_gte":{"patent_date":"2007-01-01"}},{"_lte":{"patent_date":"2007-12-31"}}]}
Patents with an inventor with the last name of "Whitney" or "Hopper" and not a design patent and with a grant date in 2007:
https://search.patentsview.org/api/v1/patents/q={"_and":[{"inventors.inventor_name_last":["Whitney","Hopper"]},{"_not":{"patent_type":"design"}},{"_gte":{"patent_date":"2007-01-01"}},{"_lte":{"patent_date":"2007-12-31"}}]}
Patents with an inventor with the last name of "Whitney" or "Hopper" or with a title that contains "cotton" or "gin" or "COBOL":
https://search.patentsview.org/api/v1/patents/q={"_or":[{"inventors.inventor_name_last":["Whitney","Hopper"]},{"_text_any":{"patent_title":"COBOL cotton gin"}}]}
Patents with an inventor with the last name of "Whitener" and with "cotton gin" in the title, or with an inventor with the last name of "Heath" and with "COBOL" in the title:
https://search.patentsview.org/api/v1/patents/q={"_or":[{"_and":[{"inventors.inventor_name_last":"Whitener"},{"_text_phrase":{"patent_title":"cotton gin"}}]},{"_and":[{"inventors.inventor_name_last":"Heath"},{"_text_all":{"patent_title":"COBOL"}}]}]}
Formats
Dates are expected to be in ISO 8601 date format: YYYY-MM-DD.
Nested fields follow the format <field>.<nested_field>
Field List (f
)
Field List Format
The field list parameter is a JSON array of the names of the fields to be returned by the query. If not provided, the API will return a default set of fields. Each API Endpoint section contains a list of the data fields that can be selected for inclusion in output datasets.
The following example would return the patent numbers, inventor names, and date patent was granted that meet the query criteria:
f=["patent_id","inventors.inventor_name_last","patent_date"]
Note that Nested fields have the format {entity}.{field_name}
. In the endpoint specification below, these fields are
shown in a containers within the parent endpoint.
Sorting (s
)
Sort Parameter Format
The sort parameter is a JSON formatted array of objects that specifies the sort order for the returned results. If empty
or not provided, the default sort order will be ascending by patent number. Each object in the array should be a pair,
with the pair's key being one of the endpoint fields, and the value is either asc
or desc
, to indicate ascending or
descending sort, respectively.
Examples:
s=[{"patent_num_times_cited_by_us_patents":"desc"}]
: Primary sort is bypatent_num_times_cited_by_us_patents
in descending order, so that patents with the most citations by other US patents will be first, and those with the fewest citations by other US patents will be last.s=[{"patent_date":"desc"},{"patent_id":"asc"}]
: Primary sort is bypatent_date
in descending order, secondarily bypatent_id
in ascending order.s=[{"citation_sequence":"desc"}]
: Primary sort is bycitation_sequence
in ascending order, so that citations are returned in the ordered they were cited.s=[{"citation_date":"desc"},{"patent_id":"asc"}]
: Primary sort is bycitation_date
in descending order, secondarily bypatent_id
in ascending order.
Options (o
)
The options parameter is a JSON formatted object of options to modify the query results. Available options are:
size
: Thesize
option specifies the number of results per page; it defaults to 100 and has a maximum of 1,000.after
: Theafter
option implements Cursor Pagination. If included, the value should be a valid value from field specified in the sort option. To get continuous pages of results, users will need to the supply value from the last record in the previous query to the subsequent query. See Pagination below
Pagination
As an example, if the sort
query is s=[{"patent_id":"desc"}]
, the option
value for the first query would
be o={"size":100}
This would return 100 records sorted by patent id in descending order.
The option value for the second query could be o={"size":100,"after":"11191202"}
where 11191202 is the last patent_id
value from the previous query.
Endpoints
Below is a list of publically available endpoints along with a list of fields corresponding to each endpoint. Each of these endpoints can be queried using the API Query Language
Some endpoints support the ability to use the GET method to get resources by ID i.e. instead of supplying field query,
users can lookup a resource by ID. The
individual endpoints that support this will have an additional GET specification with the id required show in {}
.
Granted Patent Endpoints
CPC Class/Subclass/Group
GET / POST /api/v1/cpc_class/
cpc_class_first_seen_date date
cpc_class_id string
cpc_class_last_seen_date date
cpc_class_num_assignees integer
cpc_class_num_inventors integer
cpc_class_num_patents integer
cpc_class_title text
cpc_class_years_active integer
GET /api/v1/cpc_class/{cpc_class_id}/
cpc_class_first_seen_date date
cpc_class_id string
cpc_class_last_seen_date date
cpc_class_num_assignees integer
cpc_class_num_inventors integer
cpc_class_num_patents integer
cpc_class_title text
cpc_class_years_active integer
GET / POST /api/v1/cpc_subclass/
cpc_class string
cpc_class_id string
cpc_subclass string
cpc_subclass_first_seen_date date
cpc_subclass_id string
cpc_subclass_last_seen_date date
cpc_subclass_num_assignees integer
cpc_subclass_num_inventors integer
cpc_subclass_num_patents integer
cpc_subclass_title text
cpc_subclass_years_active integer
GET /api/v1/cpc_subclass/{cpc_subclass_id}/
cpc_class string
cpc_class_id string
cpc_subclass string
cpc_subclass_first_seen_date date
cpc_subclass_id string
cpc_subclass_last_seen_date date
cpc_subclass_num_assignees integer
cpc_subclass_num_inventors integer
cpc_subclass_num_patents integer
cpc_subclass_title text
cpc_subclass_years_active integer
GET / POST /api/v1/cpc_group/
cpc_class string
cpc_class_id string
cpc_group_id string
cpc_group_title text
cpc_subclass string
cpc_subclass_id string
GET /api/v1/cpc_subclass/{cpc_group_id}/
cpc_class string
cpc_class_id string
cpc_group_id string
cpc_group_title text
cpc_subclass string
cpc_subclass_id string
IPC
GET / POST /api/v1/ipc/
ipc_class string
ipc_id string
ipc_section string
ipc_subclass string
Foreign Citations
GET / POST /api/v1/patent/foreign_citation/
patent_id string
citation_number string
citation_sequence integer
citation_date date
citation_category string
citation_country string
Patent
GET / POST /api/v1/patent/
gov_interest_statement text
patent_abstract text
patent_cpc_current_group_average_patent_processing_days integer
patent_date date
patent_detail_desc_length integer
patent_earliest_application_date date
patent_id string
patent_num_foreign_documents_cited integer
patent_num_times_cited_by_us_patents integer
patent_num_total_documents_cited integer
patent_num_us_applications_cited integer
patent_num_us_patents_cited integer
patent_processing_days integer
patent_term_extension integer
patent_title text
patent_type string
patent_uspc_current_mainclass_average_patent_processing_days integer
patent_year integer
wipo_kind string
Nested Fields
applicants
applicant_designation string
applicant_name_first text
applicant_name_last text
applicant_organization text
applicant_sequence integer
applicant_type string
location_id string
application
application_id string
application_type string
filing_date date
filing_type string
rule_47_flag boolean
series_code string
assignees
assignee string
assignee_type string
assignee_individual_name_first text
assignee_individual_name_last text
assignee_organization text
assignee_city text
assignee_state text
assignee_country text
assignee_sequence integer
attorneys
attorney_id string
attorney_name_first text
attorney_name_last text
attorney_organization text
attorney_sequence integer
botanic
latin_name string
variety string
cpc_at_issue
cpc_class string
cpc_class_id string
cpc_group string
cpc_group_id string
cpc_section string
cpc_sequence integer
cpc_subclass string
cpc_subclass_id string
cpc_type string
cpc_current
cpc_class string
cpc_class_id string
cpc_group string
cpc_group_id string
cpc_section string
cpc_sequence integer
cpc_subclass string
cpc_subclass_id string
cpc_type string
examiners
art_group string
examiner_first_name text
examiner_id string
examiner_last_name text
examiner_role string
figures
num_figures integer
num_sheets integer
foreign_priority
filing_date date
foreign_application_id string
foreign_country_filed string
priority_claim_kind string
priority_claim_sequence integer
gov_interest_contract_award_numbers
award_number string
gov_interest_organizations
fedagency_name text
level_one text
level_three text
level_two text
granted_pregrant_crosswalk
application_number string
document_number integer
inventors
inventor string
inventor_name_first text
inventor_name_last text
inventor_city text
inventor_state text
inventor_country text
inventor_sequence integer
ipcr
ipc_action_date date
ipc_class string
ipc_classification_data_source string
ipc_classification_value string
ipc_id string
ipc_main_group string
ipc_section string
ipc_sequence integer
ipc_subclass string
ipc_subgroup string
ipc_symbol_position string
pct_data
application_kind string
pct_102_date date
pct_371_date date
pct_doc_number string
pct_doc_type string
published_filed_date date
us_related_documents
published_country string
related_doc_kind string
related_doc_number string
related_doc_published_date date
related_doc_sequence integer
related_doc_status string
related_doc_type string
wipo_kind string
us_term_of_grant
disclaimer_date date
term_disclaimer string
term_extension string
term_grant string
uspc_at_issue
uspc_mainclass string
uspc_mainclass_id string
uspc_sequence integer
uspc_subclass string
uspc_subclass_id string
wipo
wipo_field string
wipo_field_id string
wipo_sequence integer
GET /api/v1/patent/{patent_id}/
gov_interest_statement text
patent_abstract text
patent_cpc_current_group_average_patent_processing_days integer
patent_date date
patent_detail_desc_length integer
patent_earliest_application_date date
patent_id string
patent_num_foreign_documents_cited integer
patent_num_times_cited_by_us_patents integer
patent_num_total_documents_cited integer
patent_num_us_applications_cited integer
patent_num_us_patents_cited integer
patent_processing_days integer
patent_term_extension integer
patent_title text
patent_type string
patent_uspc_current_mainclass_average_patent_processing_days integer
patent_year integer
wipo_kind string
Nested Fields
applicants
applicant_designation string
applicant_name_first text
applicant_name_last text
applicant_organization text
applicant_sequence integer
applicant_type string
location_id string
application
application_id string
application_type string
filing_date date
filing_type string
rule_47_flag boolean
series_code string
assignees
assignee_city text
assignee_country text
assignee_id string
assignee_individual_name_first text
assignee_individual_name_last text
assignee_location_id string
assignee_organization text
assignee_sequence integer
assignee_state text
assignee_type string
attorneys
attorney_id string
attorney_name_first text
attorney_name_last text
attorney_organization text
attorney_sequence integer
botanic
latin_name string
variety string
cpc_at_issue
cpc_class string
cpc_class_id string
cpc_group string
cpc_group_id string
cpc_section string
cpc_sequence integer
cpc_subclass string
cpc_subclass_id string
cpc_type string
cpc_current
cpc_class string
cpc_class_id string
cpc_group string
cpc_group_id string
cpc_section string
cpc_sequence integer
cpc_subclass string
cpc_subclass_id string
cpc_type string
examiners
art_group string
examiner_first_name text
examiner_id string
examiner_last_name text
examiner_role string
figures
num_figures integer
num_sheets integer
foreign_priority
filing_date date
foreign_application_id string
foreign_country_filed string
priority_claim_kind string
priority_claim_sequence integer
gov_interest_contract_award_numbers
award_number string
gov_interest_organizations
fedagency_name text
level_one text
level_three text
level_two text
granted_pregrant_crosswalk
application_number string
document_number integer
inventors
inventor_city text
inventor_country text
inventor_id string
inventor_location_id string
inventor_name_first text
inventor_name_last text
inventor_sequence integer
inventor_state text
ipcr
ipc_action_date