python - 変換 - jsonのスクリプト出力からの治療




python2 post json (2)

FEED_FORMATFEED_URI設定を手動で設定する必要があります。

settings.overrides['FEED_FORMAT'] = 'json'
settings.overrides['FEED_URI'] = 'result.json'

結果を変数に取得する場合は、リストに項目を収集するPipelineクラスを定義できます。 spider_closedシグナルハンドラを使用して結果を確認します。

import json

from twisted.internet import reactor
from scrapy.crawler import Crawler
from scrapy import log, signals
from scrapy.utils.project import get_project_settings


class MyPipeline(object):
    def process_item(self, item, spider):
        results.append(dict(item))

results = []
def spider_closed(spider):
    print results

# set up spider    
spider = TestSpider(domain='mydomain.org')

# set up settings
settings = get_project_settings()
settings.overrides['ITEM_PIPELINES'] = {'__main__.MyPipeline': 1}

# set up crawler
crawler = Crawler(settings)
crawler.signals.connect(spider_closed, signal=signals.spider_closed)
crawler.configure()
crawler.crawl(spider)

# start crawling
crawler.start()
log.start()
reactor.run() 

参考までに、Scrapyがコマンドライン引数を解析する方法を見てください

同じくPythonでstdoutをキャプチャする

私はpythonスクリプトでscrapyを実行しています

def setup_crawler(domain):
    dispatcher.connect(stop_reactor, signal=signals.spider_closed)
    spider = ArgosSpider(domain=domain)
    settings = get_project_settings()
    crawler = Crawler(settings)
    crawler.configure()
    crawler.crawl(spider)
    crawler.start()
    reactor.run()

それは正常に実行され、停止しますが、結果はどこですか? 私はjson形式で結果を欲しいです、どうすればいいですか?

result = responseInJSON

我々はコマンドを使用しているように

scrapy crawl argos -o result.json -t json

私は、基本的なScrapy APIのチュートリアルコードを次のように使って、 FEED_FORMATFEED_URICrawlerProcessコンストラクタに追加するだけで簡単に動作させることができました:

process = CrawlerProcess({
'USER_AGENT': 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1)',
'FEED_FORMAT': 'json',
'FEED_URI': 'result.json'
})




scrapy-spider