Webnovel Bot
Webnovel Bot and scraper written in one, optimized for speed.
Provides multiple choices of access for tasks
Install
pip install webnovelbot
or
warning: this method requires prior installation of browser-cookie3
pip install git+https://github.com/mHaisham/webnovelbot.git
follow the link for an example usage
Signin
there are a few hiccups that one may encounter during signing in to webnovel
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
try:
webnovel.signin(USER_EMAIL, USER_PASS)
except CaptchaException:
pass
except GuardException:
pass
Read more on handling Guard
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
chrome
firefox
opera
edge
chromium
from webnovel import WebnovelBot, Cookies
from webnovel.api import ParsedApi
webnovel = WebnovelBot(timeout=360)
cookiejar = Cookies.from_browser('chrome')
webnovel.add_cookiejar(cookiejar)
api = ParsedApi(cookiejar)
Cookies
extends from RequestsCookieJar
hence can be used as a replacement for it and vice-versa
Conversion tools
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
Goals
Primary focus of development is to reduce the usage of selenium.