Apify & CrawleeA&CApify & Crawlee
Powered by
skinny-azureS
Apify & Crawlee•3y ago•
4 replies
skinny-azure

Function isn't running when posted in api fy

Hello everyone,

I have the following code working perfectly when I am not using Apify however once I use Apify it doesn't run the second function. I am using the apify template for Scrapy .

Thanks for the help

from typing import Generator
from scrapy.responsetypes import Response
from apify import Actor
from urllib.parse import urljoin
import nest_asyncio
import scrapy
from itemadapter import ItemAdapter
from scrapy.crawler import CrawlerProcess
from scrapy.utils.project import get_project_settings
from scrapy.utils.reactor import install_reactor
from scrapy.http import Response, Request

class TitleSpider(scrapy.Spider):
    name = 'example'
    allowed_domains = ['apc.fr']
    start_urls = [
        "https://www.apc.fr/men/men-shirts.html",
    ]

    def parse(self, response: Response):
        Actor.log.info(f'TitleSpider is parsing {response}...')
        li_elements = response.css('li.product-item')
        product_links = []
        for li in li_elements:
            productlink_container = li.css('.product-link')
            product_link = productlink_container.css('a::attr(href)').get()
            if product_link:
                product_links.append(product_link)

        for link in product_links:
            yield scrapy.Request(url=link, callback=self.second_page)

    def second_page(self, response: Response):
        Actor.log.info(f'Second fonction is parsing {response}...')
        productname = response.css('h1.product-name::text').get()
        print(productname)
from typing import Generator
from scrapy.responsetypes import Response
from apify import Actor
from urllib.parse import urljoin
import nest_asyncio
import scrapy
from itemadapter import ItemAdapter
from scrapy.crawler import CrawlerProcess
from scrapy.utils.project import get_project_settings
from scrapy.utils.reactor import install_reactor
from scrapy.http import Response, Request

class TitleSpider(scrapy.Spider):
    name = 'example'
    allowed_domains = ['apc.fr']
    start_urls = [
        "https://www.apc.fr/men/men-shirts.html",
    ]

    def parse(self, response: Response):
        Actor.log.info(f'TitleSpider is parsing {response}...')
        li_elements = response.css('li.product-item')
        product_links = []
        for li in li_elements:
            productlink_container = li.css('.product-link')
            product_link = productlink_container.css('a::attr(href)').get()
            if product_link:
                product_links.append(product_link)

        for link in product_links:
            yield scrapy.Request(url=link, callback=self.second_page)

    def second_page(self, response: Response):
        Actor.log.info(f'Second fonction is parsing {response}...')
        productname = response.css('h1.product-name::text').get()
        print(productname)
Apify & Crawlee banner
Apify & CrawleeJoin
This is the official developer community of Apify and Crawlee.
14,091Members
Resources
Recent Announcements

Similar Threads

Was this page helpful?
Recent Announcements
ellativity

**Update to Store Publishing Terms and Acceptable Use Policy** Due to an influx of fraudulent reviews recently, Apify's Legal team has taken some actions to protect developers, customers, and Apify, by updating the Store Publishing Terms and Acceptable Use Policy. Please pay special attention to the updated terms in section 4 of the Store Publishing Terms here: https://docs.apify.com/legal/store-publishing-terms-and-conditions Additionally, please review the changes to section 2 of the Acceptable Use Policy here: https://docs.apify.com/legal/acceptable-use-policy If you have any questions, please ask them in <#1206131794261315594> so everyone can see the discussion. Thanks!

ellativity · 3w ago

ellativity

Hi @everyone I'm hanging out with the Creator team at Apify in https://discord.com/channels/801163717915574323/1430491198145167371 if you want to discuss Analytics and Insights!

ellativity · 4w ago

ellativity

2 things for <@&1092713625141137429> members today: 1. The Apify developer rewards program is open for registrations: https://apify.notion.site/developer-rewards This is the program where you will earn points for marketing activities. The rewards are still TBC, but the real purpose of the program is to help you structure your marketing activities and efforts. In the coming weeks, I will be populating that link with guides to help you identify the best ways to market your Actors, as well as scheduling workshops and office hours to help you create content and develop your own marketing strategy. 2. At 2PM CET (in about 80 minutes) there will be an office hour with the team behind Insights and Analytics, who want your feedback on how to improve analytics for you. Join us in https://discord.com/channels/801163717915574323/1430491198145167371 to share your ideas!

ellativity · 4w ago

Similar Threads

Running task with API
incredible-moccasinIincredible-moccasin / apify-platform
2y ago
Usage isn't adding up
clean-aquamarineCclean-aquamarine / apify-platform
3y ago
customData in input isn’t going through to output
forward-apricotFforward-apricot / apify-platform
2y ago
Page Navigation is Slow when Running in Apify
worthy-roseWworthy-rose / apify-platform
4y ago