TokenPoolBot is a simple bot for scanning new ERC-20 token pools created and filtering them based on the time created, liquidity and market cap. On each run it shows potential good token pools based on the filters.
Disclaimer: These markets are volatile and this bot just filters the new pools. If you want to take action on the output of this code, you have to check each pool by yourself and do your own research
Install the package
pip install tokenfinderbot
Basic usage (default settings)
from tokenfinderbot.tokenfinderbot import TokenBot
# bot instance
bot = TokenBot()
# run with default settings
bot.run()
Advanced usage (edit settings): See Settings Section
from tokenfinderbot.tokenfinderbot import TokenBot
# bot instance
bot = TokenBot()
# get bot settings
settings = bot.get_settings()
# change bot settings
settings.time_filter.hour = 6 # time filter hour edit
settings.liq_mc_filter.min_liq = 1000 # liquidity/market cap filter edit for min. liquidity
settings.db_name = "test" # change json db filename
# set new settings
bot.set_settings(settings)
# run with new settings
bot.run()
Notify on telegram (You should have a telegram bot token and a chat id which the bot is a member)
from tokenfinderbot.tokenfinderbot import TokenBot
# bot instance
bot = TokenBot()
# get bot settings
settings = bot.get_settings()
# change bot telegram settings
settings.telegram.notify = True
settings.telegram.bot_token = "YOUR TELEGRAM BOT TOKEN" # your telegram bot token
settings.telegram.chat_id = "xxxxxxxxxx" # chat id for chat, group or channel which the bot is a memeber of
# set new settings
bot.set_settings(settings)
# run with new settings
bot.run()
Bot settings:
-
DB Name (settings.db_name): Name of the json file used as database. This project makes use of tinydb for database. (default: "db")
-
Time Filter (settings.time_filter): Time filter is used to accept only the pools that have been created less than x hours and y minutes ago. This filter setting includes:
- Hours (settings.time_filter.hours): Hours (default: 12)
- Minutes (settings.time_filter.minutes): Minutes (default: 0)
-
Liquidity/Market Cap Filter (settings.liq_mc_filter): Filter based on liquidity and market cap which includes three settings:
- MarketCap/Liquidity Ratio (settings.liq_mc_filter.mc_liq_ratio): The minimum accepted ratio of marketcap/liquidity for the pool to be accepted. for example, 2 means the market cap must be at least 2 times the liquidity. (default: 1.5)
- Min. Market Cap (settings.liq_mc_filter.min_mc): The minimum accepted marketcap in USD (default: 100000)
- Min. Liquidity (settings.liq_mc_filter.min_liq): The minimum accepted liquidity in USD (default: 1000)
-
Update Interval (settings.update_interval): Time interval between each update of the database and calling APIs. Its unit is minutes (default: 15)
-
Telegram (settings.telegram): Telegram bot settings to get notifications on telegram:
- Notify (settings.telegram.notify): This should be True in order to activate the telegram notifications. (default: False)
- Bot Token (settings.telegram.bot_token): Your telegram bot token (default: "")
- Chat ID (settings.telegram.chat_id): Your telegram chat id. The bot should be a member of this chat. it can be a private chat, group or channel (default: "")