Skip to main content

Scrape various Untappd web pages and return as parsed dataclasses

Project description

Untappd Scraper

Web scrape public Untappd pages into data classes.

Quickstart

User queries

from untappd_scraper.user import User

users = ["gregavola"]

for user_id in users:
    user = User(user_id)
    print(f"\n{user.name=}")

    for checkin in user.activity():
        print(f"\n\t{checkin.name=}\n\t\t{checkin}")

    print("\n\nLists:")

    for userlist in user.lists():
        print(f"\n\t{userlist.name=} {userlist.num_items=}")

    print("\n\nRecent Venues:")

    for venue in user.venue_history():
        ago = datetime.now().date() - venue.last_visit
        print(
            f"\n\t{venue.name=} {venue.last_visit.strftime('%b %d %Y')} "
            + f"({ago.days} days ago)"
        )```

    print("\n\nRecent Uniques:")

    for beer in user.beer_history():
        print(f"\t{beer}, {beer.total_checkins=}")

Venue queries

from untappd_scraper.venue import Venue

venue_ids = [
    14705,  # 4 pines
    99967,  # collaroy
]

for venue_id in venue_ids:
    venue = Venue(venue_id)
    print(f"\n{venue.name=}")

    for num, checkin in enumerate(venue.activity(), start=1):
        print(f"\n\t{num=}\t{checkin.name=}\n\t\t{checkin}")

# Load a venue by name. Try to be as unambiguous as possible
venue = Venue.from_name("hotel sweeney")
print(f"\n{venue.name=} {venue.verified=}\t{venue.categories=}\n")
print("\n".join([str(beer) for beer in venue.activity()]))

for menu in venue.menus():
    print(f"\n{menu.selection=} / {menu.name=}")

    print("\n\t\t", end="")
    print("\n\t\t".join(str(beer) for beer in menu.beers))

Notes

untappd-scraper is just that - a scraper. It doesn't store data. So, for example, if you query a user's unique beer history (with User.beer_history()) you will not be able to see the entire history. Just what is public on the web, which is the most recent 25 uniques.

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

untappd_scraper-0.5.0rc2.tar.gz (459.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

untappd_scraper-0.5.0rc2-py3-none-any.whl (32.1 kB view details)

Uploaded Python 3

File details

Details for the file untappd_scraper-0.5.0rc2.tar.gz.

File metadata

  • Download URL: untappd_scraper-0.5.0rc2.tar.gz
  • Upload date:
  • Size: 459.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.14

File hashes

Hashes for untappd_scraper-0.5.0rc2.tar.gz
Algorithm Hash digest
SHA256 ddd55016f714d5d7886050b3ca7efcdd1adb2caa0b3e9c33c4bf5a3c7470d614
MD5 a8602c98b37fc63614cbfd1c54f9aa02
BLAKE2b-256 6b29e671c2605c1be8dc871ef9653538a93e31fa45edfa0a88a7bb8d2ac36b9a

See more details on using hashes here.

File details

Details for the file untappd_scraper-0.5.0rc2-py3-none-any.whl.

File metadata

File hashes

Hashes for untappd_scraper-0.5.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 7098f3554e27119160f0a89fd83d77c6b7212875db198f6dbde993e6c3e56cc6
MD5 adb1e862d8bfd2c1b72b1eb8a80fadbf
BLAKE2b-256 8c4eab3c9e9d571b9ba82d9e9cb3790e7f5d35b31c020ba1153c46b9f693198c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page