Head
2026-06-16 07:00:44 [scrapy.utils.log] INFO: Scrapy 2.14.1 started (bot: event_scrapers)
2026-06-16 07:00:44 [scrapy.utils.log] INFO: Versions:
{'lxml': '6.0.2',
'libxml2': '2.14.6',
'cssselect': '1.3.0',
'parsel': '1.10.0',
'w3lib': '2.0.0',
'Twisted': '25.5.0',
'Python': '3.12.3 (main, Mar 23 2026, 19:04:32) [GCC 13.3.0]',
'pyOpenSSL': '25.3.0 (OpenSSL 3.5.4 30 Sep 2025)',
'cryptography': '46.0.3',
'Platform': 'Linux-6.8.0-90-generic-x86_64-with-glibc2.39'}
2026-06-16 07:00:44 [scrapy.crawler] DEBUG: Using AsyncCrawlerProcess
2026-06-16 07:00:44 [asyncio] DEBUG: Using selector: EpollSelector
2026-06-16 07:00:44 [scrapy.addons] INFO: Enabled addons:
[]
2026-06-16 07:00:44 [scrapy.utils.log] DEBUG: Using reactor: twisted.internet.asyncioreactor.AsyncioSelectorReactor
2026-06-16 07:00:44 [scrapy.utils.log] DEBUG: Using asyncio event loop: asyncio.unix_events._UnixSelectorEventLoop
2026-06-16 07:00:44 [scrapy.extensions.telnet] INFO: Telnet Password: d4699ea9cc632084
2026-06-16 07:00:44 [scrapy.middleware] INFO: Enabled extensions:
['scrapy.extensions.corestats.CoreStats',
'scrapy.extensions.logcount.LogCount',
'scrapy.extensions.telnet.TelnetConsole',
'scrapy.extensions.memusage.MemoryUsage',
'scrapy.extensions.feedexport.FeedExporter',
'scrapy.extensions.logstats.LogStats']
2026-06-16 07:00:44 [scrapy.crawler] INFO: Overridden settings:
{'BOT_NAME': 'event_scrapers',
'FEED_EXPORT_ENCODING': 'utf-8',
'FEED_URI_PARAMS': <function _feed_uri_params at 0x7447ef32c540>,
'LOG_FILE': '/root/event-list-scraping/logs/event_scrapers/elm_street_books/5238f312694011f1b77d0050565fa5d9.log',
'NEWSPIDER_MODULE': 'event_scrapers.spiders',
'REQUEST_FINGERPRINTER_CLASS': 'scrapy_zyte_api.ScrapyZyteAPIRequestFingerprinter',
'SPIDER_MODULES': ['event_scrapers.spiders']}
2026-06-16 07:00:44 [scrapy_zyte_api.handler] INFO: Using a Zyte API key starting with 'ff9baec'
2026-06-16 07:00:44 [scrapy_zyte_api.handler] INFO: Using a Zyte API key starting with 'ff9baec'
2026-06-16 07:00:44 [scrapy.middleware] INFO: Enabled downloader middlewares:
['scrapy.downloadermiddlewares.offsite.OffsiteMiddleware',
'scrapy.downloadermiddlewares.httpauth.HttpAuthMiddleware',
'scrapy.downloadermiddlewares.downloadtimeout.DownloadTimeoutMiddleware',
'scrapy.downloadermiddlewares.defaultheaders.DefaultHeadersMiddleware',
'scrapy.downloadermiddlewares.useragent.UserAgentMiddleware',
'scrapy.downloadermiddlewares.retry.RetryMiddleware',
'scrapy.downloadermiddlewares.redirect.MetaRefreshMiddleware',
'scrapy.downloadermiddlewares.httpcompression.HttpCompressionMiddleware',
'scrapy.downloadermiddlewares.redirect.RedirectMiddleware',
'scrapy_zyte_api.ScrapyZyteAPIDownloaderMiddleware',
'scrapy.downloadermiddlewares.cookies.CookiesMiddleware',
'scrapy.downloadermiddlewares.httpproxy.HttpProxyMiddleware',
'scrapy.downloadermiddlewares.stats.DownloaderStats']
2026-06-16 07:00:44 [scrapy.middleware] INFO: Enabled spider middlewares:
['scrapy.spidermiddlewares.start.StartSpiderMiddleware',
'scrapy.spidermiddlewares.httperror.HttpErrorMiddleware',
'scrapy_zyte_api.ScrapyZyteAPISpiderMiddleware',
'scrapy.spidermiddlewares.referer.RefererMiddleware',
'scrapy.spidermiddlewares.urllength.UrlLengthMiddleware',
'scrapy.spidermiddlewares.depth.DepthMiddleware',
'scrapy_zyte_api.ScrapyZyteAPIRefererSpiderMiddleware']
2026-06-16 07:00:44 [scrapy.middleware] INFO: Enabled item pipelines:
['event_scrapers.pipelines.EventScrapersPipeline']
2026-06-16 07:00:44 [py.warnings] WARNING: /root/.venv/lib/python3.12/site-packages/scrapy/pipelines/__init__.py:47: ScrapyDeprecationWarning: EventScrapersPipeline.process_item() requires a spider argument, this is deprecated and the argument will not be passed in future Scrapy versions. If you need to access the spider instance you can save the crawler instance passed to from_crawler() and use its spider attribute.
self._check_mw_method_spider_arg(pipe.process_item)
2026-06-16 07:00:44 [scrapy.core.engine] INFO: Spider opened
2026-06-16 07:00:44 [py.warnings] WARNING: /root/.venv/lib/python3.12/site-packages/scrapy/core/spidermw.py:490: ScrapyDeprecationWarning: event_scrapers.spiders.elm_street_books.ElmStreetBooksSpider defines the deprecated start_requests() method. start_requests() has been deprecated in favor of a new method, start(), to support asynchronous code execution. start_requests() will stop being called in a future version of Scrapy. If you use Scrapy 2.13 or higher only, replace start_requests() with start(); note that start() is a coroutine (async def). If you need to maintain compatibility with lower Scrapy versions, when overriding start_requests() in a spider class, override start() as well; you can use super() to reuse the inherited start() implementation without copy-pasting. See the release notes of Scrapy 2.13 for details: https://docs.scrapy.org/en/2.13/news.html
warn(
2026-06-16 07:00:44 [scrapy.extensions.logstats] INFO: Crawled 0 pages (at 0 pages/min), scraped 0 items (at 0 items/min)
2026-06-16 07:00:44 [scrapy.extensions.telnet] INFO: Telnet console listening on 127.0.0.1:6023
2026-06-16 07:00:44 [zyte_api._retry] DEBUG: Starting call to 'zyte_api._async.AsyncZyteAPI.get.<locals>.request', this is the 1st time calling it.
2026-06-16 07:00:47 [scrapy.core.engine] DEBUG: Crawled (200) <GET https://elmstreetbooks.com/upcoming-events> (referer: None) ['zyte-api']
2026-06-16 07:00:47 [zyte_api._retry] DEBUG: Starting call to 'zyte_api._async.AsyncZyteAPI.get.<locals>.request', this is the 1st time calling it.
2026-06-16 07:00:47 [zyte_api._retry] DEBUG: Starting call to 'zyte_api._async.AsyncZyteAPI.get.<locals>.request', this is the 1st time calling it.
2026-06-16 07:00:47 [zyte_api._retry] DEBUG: Starting call to 'zyte_api._async.AsyncZyteAPI.get.<locals>.request', this is the 1st time calling it.
2026-06-16 07:00:47 [zyte_api._retry] DEBUG: Starting call to 'zyte_api._async.AsyncZyteAPI.get.<locals>.request', this is the 1st time calling it.
2026-06-16 07:00:47 [zyte_api._retry] DEBUG: Starting call to 'zyte_api._async.AsyncZyteAPI.get.<locals>.request', this is the 1st time calling it.
2026-06-16 07:00:49 [scrapy.core.engine] DEBUG: Crawled (200) <GET https://elmstreetbooks.com/event/2026-06-25/summer-reading-kickoff-party-fun-all-ages-new-canaan-library> (referer: None) ['zyte-api']
2026-06-16 07:00:49 [scrapy.core.engine] DEBUG: Crawled (200) <GET https://elmstreetbooks.com/event/2026-06-20/meet-greet-lauren-acampora-elm-street-books> (referer: None) ['zyte-api']
2026-06-16 07:00:49 [urllib3.connectionpool] DEBUG: Starting new HTTP connection (1): 144.91.120.141:80
2026-06-16 07:00:49 [urllib3.connectionpool] DEBUG: http://144.91.120.141:80 "POST /api/v1/raw-events/ HTTP/1.1" 201 7191
2026-06-16 07:00:49 [scrapy.core.scraper] DEBUG: Scraped from <200 https://elmstreetbooks.com/event/2026-06-25/summer-reading-kickoff-party-fun-all-ages-new-canaan-library>
{'event_url': 'https://elmstreetbooks.com/event/2026-06-25/summer-reading-kickoff-party-fun-all-ages-new-canaan-library',
'platform': 'Elm street books',
'platform_hash': 'b8137ce32aec22df65f3cc623d0a56ae',
'raw_body': '<div id="block-bookworm-content" class="inner-content">\n'
' \n'
' \n'
' <article class="eventinstance-full '
'event-details__wrapper">\n'
' <div class="event-details__image">\n'
' \n'
' <div>\n'
' \n'
' \n'
' \n'
' <img loading="lazy" '
'src="/sites/default/files/styles/event_image/public/2026-05/ncl-reading-kick.png?itok=5CgnTCKM" '
'width="295" height="295" alt="Rather">\n'
'\n'
'\n'
Tail
' \n'
' </div>\n'
'</div>\n'
' <div class="product-list__pub-date"><span '
'class="product-details__label">Publish Date: </span> \n'
' <time '
'datetime="2026-05-05T12:00:00Z">5/5/2026</time>\n'
'\n'
' </div>\n'
' </div>\n'
' </div>\n'
' <div class="product-list__middle">\n'
' <div class="product-list__description">\n'
' \n'
' <p>From the #1 bestselling author of Restart, the '
'story of a family of liars... and the son who wants to break the '
'family tradition.\n'
'</p>\n'
'<p>Trey knows the drill: His dad gets him into a school full of '
'kids with rich parents. Trey makes friends, and his dad makes '
"connections. Soon, there's the con, where Trey...</p>\n"
'\n'
'\n'
'\n'
' \n'
' <a '
'href="/book/9781338826777?ic_referral=JqfA2zBV4jZJHZ2owSb-sEJRoZJ5jMEtYv02vddJrHUwM0bXVU1AIBQlgDLu_eY8xS6nSwIb0kMCBZAmfYh0130PnFAPj-xwaB6olajeAHxjbZwILsj7ta_27VhtQxlAvye0" '
'class="product-list__description-link">Read More\n'
' <span class="visually-hidden">about Faker\n'
' </span></a>\n'
' \n'
' <div class="product-details__availability-check">\n'
' On Our Shelves Now (if qty of less than 2, please call '
'store to confirm)\n'
' </div>\n'
' \n'
' </div>\n'
' </div>\n'
' <div class="product-list__right">\n'
' <div class="product-list__actions">\n'
'<a class="button add-to-cart-link" '
'href="/add-to-cart/869789/869789/o9bFb6Tt5T32dptz?ic_referral=JqfA2zBV4jZJHZ2owSb-sEJRoZJ5jMEtYv02vddJrHUwM0bXVU1AIBQlgDLu_eY8xS6nSwIb0kMCBZAmfYh0130PnFAPj-xwaB6olajeAHxjbZwILsj7ta_27VhtQxlAvye0" '
'rel="nofollow" data-variation="869789">Add to Cart</a>\n'
' <a '
'href="/user/login?destination=/event/2026-07-15/author-talk-childrens-author-gordon-korman&wishlist_product_id=869789" '
'class="button btn-link add-to-wishlist-link" id="wishlist-link" '
'rel="nofollow" data-variation="869789" '
'data-drupal-selector="edit-wishlist">Add to wishlist</a>\n'
'</div>\n'
' </div>\n'
'</article>\n'
'\n'
' \n'
'\n'
'\n'
'\n'
'\n'
'\n'
'<article class="product-list__wrapper '
'product-list__related-books" '
'id="product-variation-wrapper--986473">\n'
' <div class="product-list__left">\n'
' <div class="product-list__image">\n'
' <div class="product-list__image--inner">\n'
' <a '
'href="/book/9781546142232?ic_referral=abb4VA0p7QGz2Eio7tWzVp5HV_xup0sfgEF8ccLFICIwM_oNv9iTNXPrD8SDa8EEjJJnxXdZYQa-AN8Y4BWb0gOtNXBtPoIQwRLrVDymulC-DR8p2ikAF0m1yB_uJKpj0rvE">\n'
' \n'
' <img '
'src="https://images.booksense.com/images/232/142/9781546142232.jpg" '
'alt="Dive #1: The Discovery" onerror="this.src = '
'\'/modules/custom/indiecommerce_bds/assets/images/no_cover.jpg\';">\n'
' \n'
' </a>\n'
' </div>\n'
' </div>\n'
' <div class="product-list__inner">\n'
' <h2 class="product-list__title"><a '
'href="/book/9781546142232?ic_referral=abb4VA0p7QGz2Eio7tWzVp5HV_xup0sfgEF8ccLFICIwM_oNv9iTNXPrD8SDa8EEjJJnxXdZYQa-AN8Y4BWb0gOtNXBtPoIQwRLrVDymulC-DR8p2ikAF0m1yB_uJKpj0rvE">\n'
' Dive #1: The Discovery\n'
' </a></h2>\n'
' <div class="product-list__author">\n'
' Gordon Korman\n'
' </div>\n'
' <div class="product-list__price">\n'
' <span class="product-list__price-sale"><span '
'class="visually-hidden">Current price: </span>\n'
' $7.99\n'
' </span>\n'
' </div>\n'
' <div class="product-list__binding">\n'
' Paperback\n'
' </div>\n'
' <div class="product-list__isbn">\n'
' <div>\n'
' <div class="product-details__label">ISBN:</div>\n'
' 9781546142232\n'
' \n'
' </div>\n'
'</div>\n'
' <div class="product-list__pub-date"><span '
'class="product-details__label">Publish Date: </span> \n'
' <time '
'datetime="2025-02-04T12:00:00Z">2/4/2025</time>\n'
'\n'
' </div>\n'
' </div>\n'
' </div>\n'
' <div class="product-list__middle">\n'
' <div class="product-list__description">\n'
' \n'
' <p>Sharks, shipwreck, and sunken treasure in this '
'action packed survival series from bestselling and award-winning '
'author Gordon Korman.\n'
'</p>\n'
"<p>Kaz, Dante, Adriana, and Star aren't the best divers in the "
"world. But they've been chosen to spend the summer exploring the "
'depths of the sea.</p>\n'
'<p>There are only a few...</p>\n'
'\n'
'\n'
'\n'
' \n'
' <a '
'href="/book/9781546142232?ic_referral=abb4VA0p7QGz2Eio7tWzVp5HV_xup0sfgEF8ccLFICIwM_oNv9iTNXPrD8SDa8EEjJJnxXdZYQa-AN8Y4BWb0gOtNXBtPoIQwRLrVDymulC-DR8p2ikAF0m1yB_uJKpj0rvE" '
'class="product-list__description-link">Read More\n'
' <span class="visually-hidden">about Dive #1: The '
'Discovery\n'
' </span></a>\n'
' \n'
' <div class="product-details__availability-check">\n'
' On Our Shelves Now (if qty of less than 2, please call '
'store to confirm)\n'
' </div>\n'
' \n'
' </div>\n'
' </div>\n'
' <div class="product-list__right">\n'
' <div class="product-list__actions">\n'
'<a class="button add-to-cart-link" '
'href="/add-to-cart/986473/986473/jnmO9TFsTYTlzpvW?ic_referral=abb4VA0p7QGz2Eio7tWzVp5HV_xup0sfgEF8ccLFICIwM_oNv9iTNXPrD8SDa8EEjJJnxXdZYQa-AN8Y4BWb0gOtNXBtPoIQwRLrVDymulC-DR8p2ikAF0m1yB_uJKpj0rvE" '
'rel="nofollow" data-variation="986473">Add to Cart</a>\n'
' <a '
'href="/user/login?destination=/event/2026-07-15/author-talk-childrens-author-gordon-korman&wishlist_product_id=986473" '
'class="button btn-link add-to-wishlist-link" id="wishlist-link" '
'rel="nofollow" data-variation="986473" '
'data-drupal-selector="edit-wishlist">Add to wishlist</a>\n'
'</div>\n'
' </div>\n'
'</article>\n'
'\n'
' </div>\n'
'</article>\n'
'\n'
'\n'
' </div>'}
2026-06-16 07:00:50 [scrapy.core.engine] INFO: Closing spider (finished)
2026-06-16 07:00:50 [scrapy.extensions.feedexport] INFO: Stored csv feed (5 items) in: output/2026/06/16/elm_street_books.csv
2026-06-16 07:00:50 [scrapy.statscollectors] INFO: Dumping Scrapy stats:
{'downloader/request_bytes': 4642,
'downloader/request_count': 6,
'downloader/request_method_count/GET': 6,
'downloader/response_bytes': 287288,
'downloader/response_count': 6,
'downloader/response_status_count/200': 6,
'elapsed_time_seconds': 5.643596,
'feedexport/success_count/FileFeedStorage': 1,
'finish_reason': 'finished',
'finish_time': datetime.datetime(2026, 6, 16, 5, 0, 50, 346842, tzinfo=datetime.timezone.utc),
'item_scraped_count': 5,
'items_per_minute': 60.0,
'log_count/DEBUG': 27,
'log_count/ERROR': 1,
'log_count/INFO': 3,
'memusage/max': 93294592,
'memusage/startup': 93294592,
'request_depth_max': 1,
'response_received_count': 6,
'responses_per_minute': 72.0,
'scheduler/dequeued': 6,
'scheduler/dequeued/memory': 6,
'scheduler/enqueued': 6,
'scheduler/enqueued/memory': 6,
'scrapy-zyte-api/429': 0,
'scrapy-zyte-api/attempts': 6,
'scrapy-zyte-api/error_ratio': 0.0,
'scrapy-zyte-api/errors': 0,
'scrapy-zyte-api/fatal_errors': 0,
'scrapy-zyte-api/mean_connection_seconds': 1.9224448408931494,
'scrapy-zyte-api/mean_response_seconds': 2.0593536800394454,
'scrapy-zyte-api/processed': 6,
'scrapy-zyte-api/request_args/customHttpRequestHeaders': 6,
'scrapy-zyte-api/request_args/httpResponseBody': 6,
'scrapy-zyte-api/request_args/httpResponseHeaders': 6,
'scrapy-zyte-api/request_args/url': 6,
'scrapy-zyte-api/status_codes/200': 6,
'scrapy-zyte-api/success': 6,
'scrapy-zyte-api/success_ratio': 1.0,
'scrapy-zyte-api/throttle_ratio': 0.0,
'start_time': datetime.datetime(2026, 6, 16, 5, 0, 44, 703246, tzinfo=datetime.timezone.utc)}
2026-06-16 07:00:50 [scrapy.core.engine] INFO: Spider closed (finished)