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

https://github.com/m-haisham/webnovelbot

Automate your webnovel interactions
https://github.com/m-haisham/webnovelbot

api bot scraper selenium webnovel

Last synced: about 2 months ago
JSON representation

Automate your webnovel interactions

Awesome Lists containing this project

README

          

# Webnovel Bot

Webnovel Bot and scraper written in one, optimized for speed.

Provides multiple choices of access for tasks

## Install

```bash
pip install webnovelbot
```

or

**warning:** this method requires prior installation of `browser-cookie3`

```bash
pip install git+https://github.com/mHaisham/webnovelbot.git
```

## [Sample][1]

follow the [link][1] for an example usage

[1]: https://github.com/mHaisham/webnovelbot/blob/master/example.py

## Signin

there are a few hiccups that one may encounter during signing in to webnovel

- **Captcha:** During the signin process user can be asked to fill in a google captcha

- **Guard:** After clicking the signin button the form can redirect the user to a guard website

you can handle them in different ways, `signin` method takes a variable `manual`
which defaults to `False`. Behaviour of the function changes depending on it.

### `manual=False`

When manual is false signin would throw exceptions corresponding to the situation

```python
try:
webnovel.signin(USER_EMAIL, USER_PASS)
except CaptchaException:
pass
except GuardException:
pass
```

[Read more] on handling Guard

[Read more]: https://github.com/mHaisham/webnovelbot/tree/master/webnovel/handlers

### `manual=True`

When manual is true the process would be expecting user input during the above mentioned situations.

It would by default wait 10 minutes for user input before throwing a `TimeoutException`.

You may define a custom time by setting `webnovel.user_timeout`

## Cookies

Webnovelbot supports using cookies from other web browsers in both selenium and api using class `Cookies`

It currently supports all browsers supported by [browser_cookie3](https://github.com/borisbabic/browser_cookie3)

`chrome` `firefox` `opera` `edge` `chromium`

```python
from webnovel import WebnovelBot, Cookies
from webnovel.api import ParsedApi

webnovel = WebnovelBot(timeout=360)

cookiejar = Cookies.from_browser('chrome')

# this will load the cookie jar into selenium
# depending on what you want to do after, you may want to reload the page
webnovel.add_cookiejar(cookiejar)

# this will create the api with the cookie jar
api = ParsedApi(cookiejar)
```

`Cookies` extends from `RequestsCookieJar` hence can be used as a replacement for it and vice-versa

## Conversion tools

```python
from webnovel.tools import UrlTools
```

UrlTools provides methods to convert and from `novel_id`, `chapter_id`, and `profile_id` to their respective urls

## Analytics

Supports multiple analytic tools with an easily extensible interface

[Read more](https://github.com/mHaisham/webnovelbot/tree/master/webnovel/analytic)

## Goals

Primary focus of development is to reduce the usage of selenium.