Skip to main content

Base library for scrapy's ItemLoader

Project description

PyPI Version Supported Python Versions Build Status Coverage report Documentation Status

itemloaders is a library that helps you collect data from HTML and XML sources.

It comes in handy to extract data from web pages, as it supports data extraction using CSS and XPath Selectors.

It’s specially useful when you need to standardize the data from many sources. For example, it allows you to have all your casting and parsing rules in a single place.

Here is an example to get you started:

from itemloaders import ItemLoader
from parsel import Selector

html_data = '''
<!DOCTYPE html>
<html>
    <head>
        <title>Some random product page</title>
    </head>
    <body>
        <div class="product_name">Some random product page</div>
        <p id="price">$ 100.12</p>
    </body>
</html>
'''
loader = ItemLoader(selector=Selector(html_data))
loader.add_xpath('name', '//div[@class="product_name"]/text()')
loader.add_xpath('name', '//div[@class="product_title"]/text()')
loader.add_css('price', '#price::text')
loader.add_value('last_updated', 'today') # you can also use literal values
item = loader.load_item()
item
# {'name': ['Some random product page'], 'price': ['$ 100.12'], 'last_updated': ['today']}

For more information, check out the documentation.

Contributing

All contributions are welcome!

  • If you want to review some code, check open Pull Requests here

  • If you want to submit a code change

    • File an issue here, if there isn’t one yet

    • Fork this repository

    • Create a branch to work on your changes

    • Push your local branch and submit a Pull Request

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

itemloaders-1.0.3.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

itemloaders-1.0.3-py3-none-any.whl (11.3 kB view details)

Uploaded Python 3

File details

Details for the file itemloaders-1.0.3.tar.gz.

File metadata

  • Download URL: itemloaders-1.0.3.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.0

File hashes

Hashes for itemloaders-1.0.3.tar.gz
Algorithm Hash digest
SHA256 a7803a1c27177d73329a0cc83a9c10de50fa4d4f37970e0194e8ae24b1fb7066
MD5 ada547a9540e8eecb4423896251bce0f
BLAKE2b-256 f2919daeea8cab0ca6cd9cebbce3d48a78f0f4abe44d2af60d4c5bfbc6eb1ea4

See more details on using hashes here.

Provenance

File details

Details for the file itemloaders-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: itemloaders-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 11.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.0

File hashes

Hashes for itemloaders-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d8f92a93d0cc9f5a7f72f01562539cb7030f7741758e764a0a8716f9b0210f7a
MD5 7e41e4ff56a83eef22deb51efe82abbd
BLAKE2b-256 b9c5bd4d083c6d5368885cb8d10ea8355d38a958a57e5bc73945fc3905a7e1ca

See more details on using hashes here.

Provenance

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