Head
2026-06-16 12:01:09 [scrapy.utils.log] INFO: Scrapy 2.14.1 started (bot: event_scrapers)
2026-06-16 12:01:09 [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 12:01:09 [scrapy.crawler] DEBUG: Using AsyncCrawlerProcess
2026-06-16 12:01:09 [asyncio] DEBUG: Using selector: EpollSelector
2026-06-16 12:01:09 [scrapy.addons] INFO: Enabled addons:
[]
2026-06-16 12:01:09 [scrapy.utils.log] DEBUG: Using reactor: twisted.internet.asyncioreactor.AsyncioSelectorReactor
2026-06-16 12:01:09 [scrapy.utils.log] DEBUG: Using asyncio event loop: asyncio.unix_events._UnixSelectorEventLoop
2026-06-16 12:01:09 [scrapy.extensions.telnet] INFO: Telnet Password: 4121e021f74d02e8
2026-06-16 12:01:09 [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 12:01:09 [scrapy.crawler] INFO: Overridden settings:
{'BOT_NAME': 'event_scrapers',
'FEED_EXPORT_ENCODING': 'utf-8',
'FEED_URI_PARAMS': <function _feed_uri_params at 0x7aed61448540>,
'LOG_FILE': '/root/event-list-scraping/logs/event_scrapers/norwalk_garden_club/4970c122696a11f1ab230050565fa5d9.log',
'NEWSPIDER_MODULE': 'event_scrapers.spiders',
'REQUEST_FINGERPRINTER_CLASS': 'scrapy_zyte_api.ScrapyZyteAPIRequestFingerprinter',
'SPIDER_MODULES': ['event_scrapers.spiders']}
2026-06-16 12:01:09 [scrapy_zyte_api.handler] INFO: Using a Zyte API key starting with 'ff9baec'
2026-06-16 12:01:09 [scrapy_zyte_api.handler] INFO: Using a Zyte API key starting with 'ff9baec'
2026-06-16 12:01:09 [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 12:01:09 [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 12:01:09 [scrapy.middleware] INFO: Enabled item pipelines:
['event_scrapers.pipelines.EventScrapersPipeline']
2026-06-16 12:01:09 [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 12:01:09 [scrapy.core.engine] INFO: Spider opened
2026-06-16 12:01:09 [py.warnings] WARNING: /root/.venv/lib/python3.12/site-packages/scrapy/core/spidermw.py:490: ScrapyDeprecationWarning: event_scrapers.spiders.norwalk_garden_club.NorwalkGardenClubSpider 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 12:01:09 [scrapy.extensions.logstats] INFO: Crawled 0 pages (at 0 pages/min), scraped 0 items (at 0 items/min)
2026-06-16 12:01:09 [scrapy.extensions.telnet] INFO: Telnet console listening on 127.0.0.1:6023
2026-06-16 12:01:10 [scrapy.core.engine] DEBUG: Crawled (200) <GET https://www.norwalkgardenclub.org/events> (referer: None)
2026-06-16 12:01:10 [scrapy_zyte_api._params] WARNING: Cookies are enabled for request <GET https://www.norwalkgardenclub.org/events/prospect-gardens>, and there are cookies in the cookiejar, but ZYTE_API_EXPERIMENTAL_COOKIES_ENABLED is False, so automatic mapping will not map cookies for this or any other request. To silence this warning, disable cookies for all requests that use automatic mapping, either with the COOKIES_ENABLED setting or with the dont_merge_cookies request metadata key.
2026-06-16 12:01:10 [scrapy.core.engine] DEBUG: Crawled (200) <GET https://www.norwalkgardenclub.org/events/garden-conservancy-open-days> (referer: https://www.norwalkgardenclub.org/events)
2026-06-16 12:01:10 [scrapy.core.engine] DEBUG: Crawled (200) <GET https://www.norwalkgardenclub.org/events/prospect-gardens> (referer: https://www.norwalkgardenclub.org/events)
2026-06-16 12:01:10 [scrapy.core.engine] DEBUG: Crawled (200) <GET https://www.norwalkgardenclub.org/events/planting-for-pollinators-how-to-create-a-thriving-pollinator-garden> (referer: https://www.norwalkgardenclub.org/events)
2026-06-16 12:01:10 [urllib3.connectionpool] DEBUG: Starting new HTTP connection (1): 144.91.120.141:80
2026-06-16 12:01:11 [urllib3.connectionpool] DEBUG: http://144.91.120.141:80 "POST /api/v1/raw-events/ HTTP/1.1" 201 5486
2026-06-16 12:01:11 [scrapy.core.scraper] DEBUG: Scraped from <200 https://www.norwalkgardenclub.org/events/garden-conservancy-open-days>
{'event_url': 'https://www.norwalkgardenclub.org/events/garden-conservancy-open-days',
'platform': 'Norwalk Garden Club',
'platform_hash': '294748ee333808cb1547818646c04ebf',
'raw_body': '<div class="events-item-wrapper events-stacked-item-wrapper" '
'data-content-field="main-content" data-item-id="">\n'
' <div class="sqs-events-collection-item events events-item">\n'
'\n'
' <a href="/events" class="eventitem-backlink">Back to All '
'Events</a>\n'
'\n'
' \n'
' <article class="eventitem " '
'id="article-69ecd2f9fcf10243db70067d" '
'data-item-id="69ecd2f9fcf10243db70067d">\n'
'\n'
' <div class="eventitem-column-meta">\n'
'\n'
' <h1 class="eventitem-title" '
'data-content-field="title">Garden Conservancy Open Days</h1>\n'
'\n'
' <ul class="eventitem-meta event-meta '
'event-meta-date-time-container" '
'data-content-field="event-date-time-range">\n'
Tail
' <time class="event-time-localized-start" '
'datetime="2026-06-15">6:00\u202fPM</time>\n'
' <span class="event-datetime-divider"></span>\n'
' <time class="event-time-localized-end" '
'datetime="2026-06-15">7:30\u202fPM</time>\n'
' </span>\n'
' </li>\n'
'\n'
' \n'
'\n'
' </ul>\n'
'\n'
' \n'
' \n'
' <ul class="eventitem-meta event-meta '
'event-meta-address-container" data-content-field="location">\n'
' <li class="eventitem-meta-item '
'eventitem-meta-address">\n'
' <span class="eventitem-meta-address-line '
'eventitem-meta-address-line--title">Bartlett Arboretum</span>\n'
' <span class="eventitem-meta-address-line">151 '
'Brookdale Road</span>\n'
' <span class="eventitem-meta-address-line">Stamford, '
'CT, 06903</span>\n'
' <span class="eventitem-meta-address-line">United '
'States</span>\n'
' <a '
'href="http://maps.google.com?q=151%20Brookdale%20Road%20Stamford,%20CT,%2006903%20United%20States" '
'class="eventitem-meta-address-maplink" '
'target="_blank">(map)</a>\n'
' </li>\n'
' </ul>\n'
' \n'
' \n'
'\n'
' <ul class="eventitem-meta event-meta '
'event-meta-addtocalendar-container">\n'
' <li class="eventitem-meta-item eventitem-meta-export '
'event-meta-item">\n'
' <a '
'href="http://www.google.com/calendar/event?action=TEMPLATE&text=Planting%20for%20Pollinators%3A%20How%20to%20Create%20a%20Thriving%20Pollinator%20Garden&dates=20260615T220000Z/20260615T233000Z&location=151%20Brookdale%20Road%2C%20Stamford%2C%20CT%2C%2006903%2C%20United%20States" '
'class="eventitem-meta-export-google">Google Calendar</a>\n'
' <span class="eventitem-meta-export-divider"></span>\n'
' <a '
'href="/events/planting-for-pollinators-how-to-create-a-thriving-pollinator-garden?format=ical" '
'class="eventitem-meta-export-ical">ICS</a>\n'
' </li>\n'
' </ul>\n'
'\n'
' \n'
' \n'
'\n'
' </div>\n'
'\n'
' <div class="eventitem-column-content">\n'
'\n'
' <div class="sqs-layout sqs-grid-12 columns-12" '
'data-layout-label="Post Body" data-type="item" '
'id="item-6a11e64b772abd73376cc444"><div class="row sqs-row"><div '
'class="col sqs-col-12 span-12"><div class="sqs-block '
'website-component-block sqs-block-website-component '
'sqs-block-html html-block" '
'data-block-css=\'["https://definitions.sqspcdn.com/website-component-definition/static-assets/website.components.html/3c171a5d-3a0e-4e72-93e4-e02dd6d36e2a_668/website.components.html.styles.css"]\' '
'data-block-scripts=\'["https://definitions.sqspcdn.com/website-component-definition/static-assets/website.components.html/3c171a5d-3a0e-4e72-93e4-e02dd6d36e2a_668/website.components.html.visitor.js"]\' '
'data-block-type="1337" '
'data-definition-name="website.components.html" '
'data-sqsp-block="text" '
'data-website-component-id="dd0915d45ec98bd9c1b0" '
'id="block-dd0915d45ec98bd9c1b0"><div '
'class="sqs-block-content"><div '
'class="sqs-text-block-container">\n'
' \n'
' <div class="sqs-html-content" data-sqsp-text-block-content><p '
'style="white-space:pre-wrap;" '
'data-rte-preserve-empty="true">Melanie Hollas, Co-chair '
'Pollinator Pathway Stamford, provides a special evening talk '
'about what a pollinator garden is, how to build one, and how to '
'make it thrive. She will also lead a walk onto the arboretum '
'grounds to identify native pollinator plants. Register on the '
'Bartlett Arboretum website. The event is free and open to '
'non-Bartlett members. Donations are appreciated.</p></div>\n'
'\n'
'\n'
' \n'
'<style id="container-styles">#block-dd0915d45ec98bd9c1b0 {\n'
' \n'
' \n'
' \n'
' }\n'
'\n'
' #block-dd0915d45ec98bd9c1b0 .sqs-html-content {\n'
' \n'
' }\n'
'\n'
' #block-dd0915d45ec98bd9c1b0 {\n'
' mix-blend-mode: var(--tweak-text-block-blend\n'
' );\n'
' border-radius: var(--tweak-text-block-radius);\n'
' }\n'
'\n'
' \n'
' \n'
'\n'
'\n'
'\n'
' \n'
' \n'
'\n'
' \n'
'</style>\n'
'\n'
'<style id="override-container-styles">\n'
' @media screen and (max-width: 767px) {\n'
' \n'
' \n'
'\n'
'#block-dd0915d45ec98bd9c1b0 {\n'
' \n'
' }\n'
' }\n'
' \n'
' \n'
' @media screen and (max-width: 767px) {\n'
' #block-dd0915d45ec98bd9c1b0 .sqs-html-content {\n'
' \n'
' }\n'
' }\n'
' \n'
' @media screen and (max-width: 767px) {\n'
' \n'
' \n'
'\n'
' \n'
' \n'
' \n'
' }</style>\n'
'\n'
'<style class="transform-overrides-vars">\n'
' \n'
' </style>\n'
'\n'
'\n'
'\n'
'</div>\n'
'</div></div></div></div></div>\n'
'\n'
' \n'
' <div class="eventitem-content-footer">\n'
'\n'
' \n'
'\n'
' \n'
' </div>\n'
' \n'
'\n'
' </div>\n'
'\n'
' <div class="clear"></div>\n'
'\n'
' </article>\n'
'\n'
' \n'
'\n'
' <div class="clear"></div>\n'
'\n'
'</div>\n'
'\n'
'</div>'}
2026-06-16 12:01:11 [scrapy.core.engine] INFO: Closing spider (finished)
2026-06-16 12:01:11 [scrapy.extensions.feedexport] INFO: Stored csv feed (3 items) in: output/2026/06/16/norwalk_garden_club.csv
2026-06-16 12:01:11 [scrapy.statscollectors] INFO: Dumping Scrapy stats:
{'downloader/request_bytes': 1415,
'downloader/request_count': 4,
'downloader/request_method_count/GET': 4,
'downloader/response_bytes': 95184,
'downloader/response_count': 4,
'downloader/response_status_count/200': 4,
'elapsed_time_seconds': 1.908754,
'feedexport/success_count/FileFeedStorage': 1,
'finish_reason': 'finished',
'finish_time': datetime.datetime(2026, 6, 16, 10, 1, 11, 370357, tzinfo=datetime.timezone.utc),
'httpcompression/response_bytes': 806584,
'httpcompression/response_count': 4,
'item_scraped_count': 3,
'items_per_minute': 180.0,
'log_count/DEBUG': 13,
'log_count/ERROR': 1,
'log_count/INFO': 3,
'log_count/WARNING': 1,
'memusage/max': 93167616,
'memusage/startup': 93167616,
'request_depth_max': 1,
'response_received_count': 4,
'responses_per_minute': 240.0,
'scheduler/dequeued': 4,
'scheduler/dequeued/memory': 4,
'scheduler/enqueued': 4,
'scheduler/enqueued/memory': 4,
'start_time': datetime.datetime(2026, 6, 16, 10, 1, 9, 461603, tzinfo=datetime.timezone.utc)}
2026-06-16 12:01:11 [scrapy.core.engine] INFO: Spider closed (finished)