AlchemyLanguage is a collection of text analysis methods that provide deeper insight into your text or HTML content. See the Getting Started topic to learn how to get started with AlchemyLanguage and other Watson services. For more AlchemyLanguage details and examples, see the API reference and documentation.
To see which languages are supported for each function, refer to each function's entry in the API reference.
By default, AlchemyLanguage automatically detects the language of your source text. You can manually specify the language of your content with the language
query parameter. (e.g. language=spanish
)
When you use an HTML or URL function of the API, AlchemyLanguage cleans the content to prepare the source text for the analysis. The sourceText
parameter allows you to customize the cleaning process with the following options:
cleaned_or_raw
(default) -- Removes website elements such as links, ads, etc. If cleaning fails, raw web page text is usedcleaned
-- Removes website elements such as links, ads, etc.raw
-- Uses raw web page text with no cleaningcquery
-- Uses the visual constraints query that you specify in the cquery
parameter. See the documentation for details about visual constraints queries.xpath
-- Uses the XPath query that you specify in the xpath
parameterxpath_or_raw
-- Uses the results of an XPath query, falling back to plain text if the XPath query returns nothingcleaned_and_xpath
-- Uses the results of an XPath query on cleaned web page textThe Combined Call method allows you to use multiple AlchemyLanguage functions in one request. This example uses a Combined Call to get entities and keywords from the IBM website and returns sentiment information for each result.
This example requires AlchemyLanguage service credentials and Node.js.
$ npm install watson-developer-cloud
API_KEY
with your AlchemyAPI key:var AlchemyLanguageV1 = require('watson-developer-cloud/alchemy-language/v1');
var alchemy_language = AlchemyLanguageV1({
api_key: 'API_KEY'
})
var parameters = {
extract: 'entities,keywords',
sentiment: 1,
url: 'https://www.ibm.com/us-en/'
};
alchemy_language.combined(parameters, function (err, response) {
if (err)
console.log('error:', err);
else
console.log(JSON.stringify(response, null, 2));
});
$ node app.js
AlchemyLanguage's Targeted Sentiment feature can search your content for target phrases and return sentiment information for each result.
This example requires AlchemyLanguage service credentials and Node.js
$ npm install watson-developer-cloud
API_KEY
with your AlchemyAPI key:var AlchemyLanguageV1 = require('watson-developer-cloud/alchemy-language/v1');
var alchemy_language = new AlchemyLanguageV1({
api_key: 'API_KEY'
})
var parameters = {
text: 'Grapes are the best! I hate peaches.',
targets: [
'grapes',
'peaches'
]
};
alchemy_language.sentiment(parameters, function (err, response) {
if (err)
console.log('error:', err);
else
console.log(JSON.stringify(response, null, 2));
});
$ node app.js
AlchemyLanguage can detect general concepts referenced in your content. The service returns Linked Data links for each concept and a URL to a relevant website when possible.
This example requires AlchemyLanguage service credentials and Node.js
$ npm install watson-developer-cloud
API_KEY
with your AlchemyAPI key.var AlchemyLanguageV1 = require('watson-developer-cloud/alchemy-language/v1');
var alchemy_language = new AlchemyLanguageV1({
api_key: 'API_KEY'
})
var parameters = {
url: 'http://www.cnn.com'
};
alchemy_language.concepts(parameters, function (err, response) {
if (err)
console.log('error:', err);
else
console.log(JSON.stringify(response, null, 2));
});
$ node app.js