unprint is a web scraping utility built around JSDOM, providing convenience methods for quickly extracting common data types.
npm install unprint
const unprint = require('unprint');
unprint.options({
headers: {
'User-Agent': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/106.0.0.0 Safari/537.36'
},
})
For optimal flexibility, unprint query methods can be used with or without initialization. If you already have access to DOM elements using another library or unprint instance, you can query it by using the uninitialized query
methods provided directly from the library, and passing the element as the first argument, as such:
unprint.query.element(element, 'h1#title')
// HTMLHeadingElement
Both unprint.get()
and unprint.init()
return its query
methods pre-initialized, removing the element argument in favor of the element retrieved or received. Initialized query methods therefore will not accept a custom element, usually expecting the selector as the first argument instead.
const result = await unprint.get('http://localhost:3101/html');
const { query } = result.context;
query.element('h1#title'); // HTMLHeadingElement
const result = await fetch('http://localhost:3101/html');
const body = await res.text();
const { query } = await unprint.init(body);
query.element('h1#title'); // HTMLHeadingElement
From here on, the query methods will be described in their initialized form. The API for the uninitialized methods is identical, except for the element passed as the first argument
The selector can be a CSS selector, an XPath selector starting with /
, or an array of either or both acting as fallbacks. If the selector is falsy, the input element will be used.
Most methods can be used in plural, returning an array of results, i.e. query.elements()
, query.dates()
.
query.element([selector], [options])
Returns the element node directly.
query.attribute(selector, attribute, [options])
or query.attr()
Return the contents of an attribute. Alias for query.element([selector], { attribute: [attribute] })
.
query.exists(selector, [options])
Return the presence of an element as a boolean.
query.count(selector, [options])
Return the number of elements that match the selector.
query.content([selector], [options])
Return the text contents of an element (.textContent
).
query.number([selector], [options])
Options
match
: The regular expression to use to extract a number from text, default/\d+(\.\d+)?/
for decimal numbers.matchIndex
: The index of the match result, useful for expressions containing groups or a global flag, default0
.separator
: Whether to use.
(Europe) or,
(US) as the decimal separator, default.
Return the contents of the element or attribute as a Number primitive.
query.content([selector], [options])
Return the HTML contents of an element (.innerHTML
).
query.text([selector], [options])
Return the text contents of an element, skipping non-text children, as opposed to querying content.
Options
join
: Join text nodes into one stringtrim
: Remove excess whitespacefilter
: Remove empty text nodes
query.url([selector], [options])
Options
origin
: The hostname to prefix when it is not included in the URL (/path
).protocol
: The protocol to use when it is not included in the URL (:www.example.com
, defaulthttp
).
Returns the href
from an anchor element (or any other specified target) as a string.
query.image([selector], [options])
or query.img()
Options:
- All options supported by
query.url()
.
Returns the src
from an image element (or any other specified target) as a string.
query.dataset(selector, property, [options])
or query.data()
Return the contents of a data-
attribute.
query.sourceSet([selector], [options])
or query.srcSet()
Options:
includeDescriptor
: Produce an array of{ descriptor, url }
instead of URL strings.- All options supported by
query.url()
.
Returns an array of media URLs from the srcset
of an media element as strings sorted by their descriptor from large to small.
query.video([selector], [options])
Options:
- All options supported by
query.url()
.
Returns the src
from an video source element (or any other specified target) as a string.
query.date(selector, format, [options])
Arguments
format
(string, array): The input format as a string or array of strings described by the Moment.js docs.
Options
match
(RegExp): The text to extract before attempting to parse it as a date. The default expression will attempt to extract any of 01-01-1970, 1970-01-01, 01/01/1970 or January 1, 1970 with optional 00:00[:00] time.matchIndex
: The index of the match result, useful for expressions containing groups or a global flag, default0
.timezone
(string): The name of the input timezone, defaults to 'UTC'.
Returns a Date object.
query.duration(selector, format, [options])
or query.dur
Options
match
(RegExp): The text to extract before attempting to parse it as a duration. The default expression will attempt to extract(hh:)mm:ss
andPT##H##M##S
.
Returns the duration in seconds as a number.
query.json([selector], [options])
Returns the parsed JSON content of an element as an object.
query.style([selector], [options])
Options
styleAttribute
: the CSS style attribute to extract, returns an object with all properties by default.
Returns the CSS style attributes of an element as an object.
unprint.get(url, [options])
unprint.post(url, body, [options])
Options
select
: Pre-query and initialize a specific element on the pageselectAll
: Pre-query and initialize multiple specific element on the page
Returns
{
context: { // using select or no option
query, // (object) unprint querying methods
},
context: [{ // using selectAll
query,
}],
html, // (string) HTML body
data, // (object) parsed JSON response
status, // (number) HTTP status code
ok, // (boolean) status code >= 200 and < 300
response, // (object) the original axios response object, alias 'res'
res, // (object) alias for 'response'
}