TextRazor's API helps you rapidly build state-of-the-art language processing technology into your application.
Our main analysis endpoint offers a simple combined call that allows you to perform several different analyses on the same document, for example extracting both the entities mentioned in the text and relations between them. The API allows callers to specify a number of extractors, which control the range of TextRazor's language analysis features.
If you have any queries please contact us at support@textrazor.com and we will get back to you promptly. We'd also love to hear from you if you have any ideas for improving the API or documentation.
The TextRazor PHP SDK is self contained in a single file, with only libcurl as a dependency. You can pick up the latest source from GitHub, and simply copy textrazor.php into your project.
Alternatively you can install using composer.json if you are using Composer to manage dependencies.
The TextRazor API identifies each of your requests by your unique API Key, which you can find in the console.
To set the TextRazor API key globally for all requests, call TextRazorSettings::setApiKey($api_key)
at the start of your application.
require_once('TextRazor.php'); TextRazorSettings::setApiKey($YOUR_API_KEY); $text = 'Barclays misled shareholders and the public about one of the biggest investments in the banks history, a BBC Panorama investigation has found.'; $textrazor = new TextRazor(); $textrazor->addExtractor('entities'); $response = $textrazor->analyze($text); if (isset($response['response']['entities'])) { foreach ($response['response']['entities'] as $entity) { print($entity['entityId']); print(PHP_EOL); } }
The TextRazor PHP SDK throws an Exception
whenever it is unable to process your request for any reason.
This comes with a descriptive message explaining the problem.
TextRazor errors are reported with their corresponding HTTP error codes and a descriptive message:
200: OK
400: Bad Request
401: Unauthorized
413: Request too large
500: Internal Server Error
Please check the TextRazor status page for updates on any system-wide issues.
To handle any intermittent connection issues we recommend that you design your application to gracefully retry sending failed requests several times before stopping and logging the error. TextRazor operates a resilient high-availability infrastructure, so any potential disruption should be kept to a minimum.
TextRazor was designed to work out of the box with a wide range of different types of content. However there are several steps you can take to help improve the system further for your specific application:
Please do not hesitate to contact us for help with getting the most out of the system for your use case.
All TextRazor analysis functionality is exposed in the TextRazor
class. To process a document, create a TextRazor
instance.
Then add the extractors you would like to use, along with any other options. Calls toanalyze()
and analyzeUrl()
will then process a string or URL.
This class is threadsafe once initialized with the request options. You should create a new instance for each request if you are likely to be changing the request options in a multithreaded environment.
analyze(text)
Calls the TextRazor API with the provided UTF-8 encoded text.
Returns a Response
with the parsed data on success. Raises an Exception
on failure.
analyzeUrl(url)
Calls the TextRazor API with the provided url.
TextRazor will first download the contents of this URL, and then process the resulting text.
TextRazor will only attempt to analyze text documents. Any invalid UTF-8 characters will be replaced with a space character and ignored. TextRazor limits the total download size to approximately 1M. Any larger documents will be truncated to that size, and a warning will be returned in the response.
By default, TextRazor will clean all HTML prior to processing. For more control of the cleanup process,
see the setCleanupMode
option.
Returns a Response
with the parsed data on success.
Raises an Exception
on failure.
setExtractors($extractors)
Sets a list of “Extractors”, which tells TextRazor which analysis functions to perform on your text. For optimal performance, only select the extractors that are explicitly required by your application.
addExtractor($extractor)
Adds a single “Extractor”, which tells TextRazor which analysis functions to perform on your text. For optimal performance, only select the extractors that are explicitly required by your application.
setRules($rules)
setCleanupHTML($cleanup_html)
setCleanupMode($cleanupMode)
Controls the preprocessing cleanup mode that TextRazor will apply to your content before analysis. For all options aside from "raw" any position offsets returned will apply to the final cleaned text, not the raw HTML. If the cleaned text is required please see the cleanup_return_cleaned option.
setCleanupReturnCleaned($cleanupReturnCleaned)
setCleanupReturnRaw($cleanupReturnRaw)
setCleanupUseMetadata($cleanupUseMetadata)
When use_metadata is True, TextRazor will use metadata extracted from your document to help in the disambiguation/extraction process. This include HTML titles and metadata, and can significantly improve results for shorter documents without much other content.
This option has no effect when cleanup_mode is 'raw'. Defaults to True.
setDownloadUserAgent($downloadUserAgent)
Sets the User-Agent header to be used when downloading over HTTP. This should be a descriptive string identifying your application, or an end user's browser user agent if you are performing live requests from a given user.
Defaults to "TextRazor Downloader (https://www.textrazor.com)"
setLanguageOverride($language_override)
setEnableCompression($do_compression)
setEnableEncryption($do_encryption)
addEntityDictionary($dictionaryId)
Adds a custom entity Dictionary ID to the request. Entries in this dictionary will be matched against your content, where a match is found the entity is returned as part of the standard Entity response. The dictionaryId should be a string ID corresponding to a Dictionary you have previously configured through the Dictionary interface.
addDbpediaTypeFilter($filter)
addFreebaseTypeFilter($filter)
setAllowOverlap($allow_overlap)
setClassifiers($classifiers)
Sets a list of classifiers to evaluate against your document. Each entry should be a string ID corresponding to either one of TextRazor's default classifiers, or one you have previously configured through the ClassifierManager interface.
If you aren't tied to a particular taxonomy version, the current textrazor_mediatopics_2023Q1 is a sound starting point for many classification projects.
addClassifier($classifierId)
time
response
ok
error
message
customAnnotationOutput
cleanedText
rawText
entailments
Entailment
across all sentences in the response.
entities
Entity
across all sentences in the response.
topics
Topic
in the response.
categories
ScoredCategory
in the response.
nounPhrases
NounPhrase
in the response.
properties
Property
across all sentences in the response.
relations
Relation
across all sentences in the response.
sentences
Sentence
in the response.
matchingRules
language
languageIsReliable
{ "time":"TIME", "response":{ "cleanedText":"CLEANED_TEXT", "sentences":[SENTENCE_JSON, ...], "entities":[ENTITY_JSON, ...], "categories":[CATEGORY_JSON, ...], "topics":[TOPIC_JSON, ...], "entailments":[ENTAILMENT_JSON, ...], "relations":[RELATION_JSON, ...], "properties":[PROPERTY_JSON, ...], "nounPhrases":[NOUNPHRASE_JSON, ...], } }
entityId
entityEnglishId
customEntityId
confidenceScore
type
freebaseTypes
freebaseId
wikidataId
matchingTokens
matchedText
data
relevanceScore
wikiLink
Represents a single “Named Entity” extracted from text.
Each entity is disambiguated to Wikipedia and Freebase concepts wherever possible. Where the entity could not be linked the relevant properties will return None.
Entities are returned with both Confidence and Relevance scores when possible. These measure slightly different things. The confidence score is a measure of the engine's confidence that the entity is a valid entity given the document context, whereas the relevance score measures how on-topic or important that entity is to the document. As an example, a news story mentioning "Barack Obama" in passing would assign high confidence to the "President" entity. If the story isn't about politics, however, the same entity might have a low relevance score.
Scores can vary if the same entity is mentioned more than once. As an entity is mentioned in different contexts the engine will report different scores.
label
score
wikiLink
wikidataId
Represents a single “Topic” extracted from text.
categoryId
label
score
The score TextRazor has assigned to this category, between 0 and 1.
To avoid false positives you might want to ignore categories below a certain score - a good starting point would be 0.5. The best way to find an appropriate threshold is to run a sample set of your documents through the system and manually inspect the results.
classifierId
Represents a single “Category” that matches your document.
contextScore
entailedTree
wordPositions
priorScore
score
Represents a single “entailment” derived from the source text.
Please note - If you need the source word for each Entailment
you must request
the "words" extractor.
wordPositions
relation
wordPositions
Represents a multi-word phrase extracted from a sentence.
To extract the full text of the noun phrase from the original content you must add the "words" extractor, and use the word offsets to recreate the original string.
wordPositions
propertyPositions
Represents a property relation extracted from raw text. A property implies an “is-a” or “has-a” relationship between the predicate (or focus) and its property.
params
RelationParam
of this relation.
wordPositions
Represents a grammatical relation between words. Typically owns a number of RelationParam
, representing the SUBJECT and OBJECT of the relation.
To extract the full text of the relation predicate or param from the original content you must add the "words" extractor, and use the word offsets to recreate the original string.
endingPos
startingPos
lemma
parentPosition
partOfSpeech
senses
spellingSuggestions
position
relationToParent
stem
token
Represents a single Word (token) extracted by TextRazor.
words
Word
in this sentence.
Represents a single sentence extracted by TextRazor.
TextRazor Entity Dictionaries allow you to augment the TextRazor entity extraction system with custom entities that are relevant to your application.
Entity Dictionaries are useful for identifying domain specific entities that may not be common enough for TextRazor to know about out of the box - examples might be Product names, Drug names, and specific person names.
TextRazor supports flexible, high performance matching of dictionaries up to several million entries, limited only by your account plan. Entries are automatically indexed and distributed across our analysis infrastructure to ensure they scale seamlessly with your application.
Once you have created a dictionary, add its ID to your analysis requests with addEntityDictionary($dictionaryId)
. TextRazor will look for any DictionaryEntry in the dictionary that
can be matched to your document, and return it as part of the standard Entity response.
createDictionary($id, $matchType=NULL, $caseInsensitive=NULL, $language=NULL)
Creates a new dictionary.
See the properties of class Dictionary for valid options.
TextRazorSettings::setApiKey($api_key); $dict = new DictionaryManager(); $dict->createDictionary('developers', 'STEM', true, 'any');
allDictionaries()
Returns a list of all Dictionary in your account.
$dict->allDictionaries();
getDictionary($id)
Returns a Dictionary object by id.
$dict->getDictionary('developers'));
deleteDictionary($id)
Deletes a dictionary and all its entries by id.
$dict->deleteDictionary('developers');
allEntries($id, $limit=NULL, $offset=NULL)
Returns a AllDictionaryEntriesResponse containing all DictionaryEntry for a dictionary, along with paging information.
Larger dictionaries can be too large to download all at once. Where possible it is recommended that you use limit and offset paramaters to control the TextRazor response, rather than filtering client side.
$dict->allEntries('developers', 10);
addEntries($id, $entries)
Adds entries to a dictionary.
Entries must be a list corresponding to properties of the new DictionaryEntry objects. At a minimum this would be [{'text':'test text to match'}].
$new_entities = array(); array_push($new_entities, array('id' => 'DEV1', 'text' => 'Andrei Alexandrescu')); $dict->addEntries('developers', $new_entities);
getEntry($dictionary_id, $entry_id)
Retrieves a specific DictionaryEntry by dictionary id and entry id.
$dict->getEntry('developers', 'DEV1');
deleteEntry($dictionary_id, $entry_id)
Deletes a specific DictionaryEntry by dictionary id and entry id.
For performance reasons it's always faster to perform major changes to dictionaries by deleting and recreating the whole dictionary rather than removing many individual entries.
$dict->deleteEntry('developers', 'DEV1');
Users on any of our paid plans can create up to 10 dictionaries, with a total of 10,000 entries. TextRazor supports custom dictionaries of millions of entries, please contact us to discuss increasing this limit for your account.
Free account holders are able to create 1 Dictionary with a total of 50 Entries.
matchType
Controls any pre-processing done on your dictionary before matching.
Defaults to '
'.caseInsensitive
When True, this dictionary will match both uppercase and lowercase characters.
Defaults to '
'id
The unique identifier for this dictionary.
language
When set to a ISO-639-2 language code, this dictionary will only match documents of the corresponding language.
When set to 'any', this dictionary will match any document.
Defaults to '
'Represents a single Dictionary, uniqely identified by an id. Each Dictionary owns a set of DictionaryEntry.
Dictionary and DictionaryEntry can only be manipulated through the DictionaryManager object.
Represents a single dictionary entry, belonging to a Dictionary object.
id
Unique ID for this entry, used to identify and manipulate specific entries.
Defaults to an automatically generated unique id.
text
String representing the text to match to this DictionaryEntry.
data
A dictionary mapping string keys to lists of string data values. Where TextRazor matches this entry to your content in analysis, it will return the dictionary as part of the entity response.
This is useful for adding application-specific metadata to each entry. Dictionary data is limited to a maximum of 10 keys, and a total of 1000 characters across all the mapped values.
{'type':['people', 'person', 'politician']}
TextRazor can classify your documents according to the IPTC Media Topics, IPTC Newscode or IAB QAG taxonomies using our predefined models.
Sometimes the categories you might be interested in aren't well represented by off-the-shelf classifiers. TextRazor gives you the flexibility to create a customized model for your particular project.
TextRazor uses "concept queries" to define new categories. These are similar to the sort of boolean query that you might type into a search engine, except they query the semantic meaning of the document you are analyzing. Each concept query uses a word or two in English to define your category.
For an example of how to create a custom classifier please see our tutorials. If you aren't getting the results you need, please contact us, we'd be happy to help.
The ClassifierManager interface offers a simple interface for creating and managing your classifiers. Classifiers only need to be uploaded once, they are safetly stored on our servers to use with future analyze requests. Simply add the classifier name to your request's "classifiers" list.
createClassifier($classifierId, $categories)
Creates a new classifier using the provided list of Category.
See the properties of class Category for valid options.
require_once('TextRazor.php'); TextRazorSettings::setApiKey('YOUR_API_KEY_HERE'); $manager = new ClassifierManager(); $newCategories = array(); array_push($newCategories, array('categoryId' => '1', 'query' => "concept('banking')")); array_push($newCategories, array('categoryId' => '2', 'query' => "concept('health')")); $manager->createClassifier('my_test_classifier', $newCategories);
deleteClassifier($classifierId)
Deletes a Classifier and all its Categories by id.
$manager->deleteClassifier($classifierId);
allCategories($classifierId, $limit=NULL, $offset=NULL)
Returns a AllCategoriesResponse containing all Category for a classifier, along with paging information.
Larger classifiers can be too large to download all at once. Where possible it is recommended that you use limit and offset paramaters to control the TextRazor response, rather than filtering client side.
$manager->allCategories($classifierId);
deleteCategory($classifierID, $categoryID)
Deletes a Category object by id.
For performance reasons it's always better to delete and recreate a whole classifier rather than its individual categories one at a time.
$manager->deleteCategory($classifierID, '1');
getCategory($classifierId, $categoryId)
Returns a Category object by id.
$manager->getCategory($classifierID, '1');
Users on any of our paid plans can create up to 10 Classifiers, with a total of 1000 categories. Please contact us to discuss increasing this limit for your account.
Free account holders are able to create 1 Classifier with a total of 50 Categories.
There are no restrictions on the use of classifiers that have been pre-defined by TextRazor.
categoryId
label
query
Represents a single Category that belongs to a Classifier. Each category consists of a unique ID, and a query at a minimum.
{ "categoryId" : "100", "label" : "Golf", "query" : "concept('sport>golf')" }
Allows you to retrieve data about your TextRazor account, designed to help manage and control your usage.
getAccount()
Returns a complete Account object.
The account endpoint is read only. Calls to this endpoint do not count towards your daily quota.
plan
concurrentRequestLimit
concurrentRequestsUsed
planDailyIncludedRequests
requestsUsedToday