An open API service indexing awesome lists of open source software.

https://github.com/eugen1j/aioscrapy

Python asynchronous library for web scrapping
https://github.com/eugen1j/aioscrapy

asyncio crawler python-crawler python37 webscraper

Last synced: 3 months ago
JSON representation

Python asynchronous library for web scrapping

Awesome Lists containing this project

README

          

# Python async library for web scraping

[![PyPI version](https://badge.fury.io/py/aioscrapy.svg)](https://badge.fury.io/py/aioscrapy)
[![License: MIT](https://img.shields.io/badge/License-MIT-green.svg)](https://github.com/eugen1j/aioscrapy/blob/master/LICENSE)

[![Build Status](https://api.travis-ci.com/eugen1j/aioscrapy.svg?branch=master)](https://travis-ci.com/github/eugen1j/aioscrapy)
[![codecov](https://codecov.io/gh/eugen1j/aioscrapy/branch/master/graph/badge.svg)](https://codecov.io/gh/eugen1j/aioscrapy)
[![codebeat badge](https://codebeat.co/badges/c494c251-c554-4f61-be57-6ca484ae7ba9)](https://codebeat.co/projects/github-com-eugen1j-aioscrapy-master)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/54e3d1b41bed4c9fb62e25483d1fe1eb)](https://www.codacy.com/app/eugen1j/aioscrapy?utm_source=github.com&utm_medium=referral&utm_content=eugen1j/aioscrapy&utm_campaign=Badge_Grade)

## Installing

pip install aioscrapy

## Usage

Plain text scraping
```python
import asyncio
import json

from aioscrapy import Client, WebTextClient, SingleSessionPool, Dispatcher, SimpleWorker

class CustomClient(Client[str, dict]):
def __init__(self, client: WebTextClient):
self._client = client

async def fetch(self, key: str) -> dict:
data = await self._client.fetch(key)
return json.loads(data)

async def main():
pool = SingleSessionPool()
dispatcher = Dispatcher(['https://httpbin.org/get'])
client = CustomClient(WebTextClient(pool))
worker = SimpleWorker(dispatcher, client)

result = await worker.run()
return result

loop = asyncio.get_event_loop()
print(loop.run_until_complete(main()))
```

Byte content downloading
```python
import asyncio

from aioscrapy import Client, WebByteClient, SingleSessionPool, Dispatcher, SimpleWorker

class CustomClient(Client[str, bytes]):
def __init__(self, client: WebByteClient):
self._client = client

async def fetch(self, key: str) -> bytes:
data = await self._client.fetch(key)
return data

async def main():
pool = SingleSessionPool()
dispatcher = Dispatcher(['https://httpbin.org/image'])
client = CustomClient(WebByteClient(pool))
worker = SimpleWorker(dispatcher, client)

result = await worker.run()
return result

loop = asyncio.get_event_loop()
data: dict = loop.run_until_complete(main())
for url, byte_content in data.items():
print(url + ": " + str(len(byte_content)) + " bytes")
```