{"id":25803552,"url":"https://github.com/lixelv/cur-convert-bot","last_synced_at":"2025-02-27T17:56:24.584Z","repository":{"id":197091146,"uuid":"697975423","full_name":"lixelv/cur-convert-bot","owner":"lixelv","description":"This is bot for converting the currency","archived":false,"fork":false,"pushed_at":"2023-10-22T21:55:22.000Z","size":47,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-02-23T20:52:06.089Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/lixelv.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null}},"created_at":"2023-09-28T21:40:40.000Z","updated_at":"2023-10-28T06:44:57.000Z","dependencies_parsed_at":"2023-10-02T02:00:34.776Z","dependency_job_id":"b803c914-5e9f-4a3d-b0f0-39c8a5e599bc","html_url":"https://github.com/lixelv/cur-convert-bot","commit_stats":null,"previous_names":["lixelv/cur-convert-bot"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lixelv%2Fcur-convert-bot","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lixelv%2Fcur-convert-bot/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lixelv%2Fcur-convert-bot/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lixelv%2Fcur-convert-bot/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/lixelv","download_url":"https://codeload.github.com/lixelv/cur-convert-bot/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":241041034,"owners_count":19898975,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-02-27T17:56:22.615Z","updated_at":"2025-02-27T17:56:24.560Z","avatar_url":"https://github.com/lixelv.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"cnf.py:\n```py\nfrom aiogram import Bot, Dispatcher, types\nfrom envparse import env\nfrom db import DB\n\nsql = DB('db.db')\n\nenv.read_envfile('.env')\n\ntoken = env('TELEGRAM')\n\nbot = Bot(token)\ndp = Dispatcher(bot)\n\ndef inline(lst: list, width: int = 6, f_t: str = '') -\u003e types.InlineKeyboardMarkup:\n    kb = types.InlineKeyboardMarkup(row_width=width, width=1200)\n    button_lst = []\n    for item in lst:\n        button_lst.append(types.InlineKeyboardButton(text=item, callback_data=f_t+item))\n\n    kb.add(*button_lst)\n\n    return kb\n\ndef cur_(f_t: str = '') -\u003e types.InlineKeyboardMarkup:\n    return inline(['RUB', 'USD', 'EUR', 'UAH', 'BYN', 'KZT', 'GBP', 'CNY', 'CHF', 'JPY', 'CAD', 'AUD', 'PLN', 'INR', 'SEK', 'TRY', 'NOK', 'DKK', 'CZK', 'AZN', 'AMD', 'KGS', 'UZS', 'TJS', 'MDL', 'BRL', 'SGD', 'HKD', 'EGP', 'ZAR', 'BGN', 'QAR', 'AED', 'THB', 'VND', 'GEL', 'HUF', 'IDR', 'NZD', 'KRW', 'TMT', 'XDR', 'RSD', 'RON'], f_t=f_t)\n\nstart_ = \"Привет\\! Я был создан чтобы конвертировать валюты\\,\" \\\n         \"\\nИспользуй команду */currency* чтобы конвертировать валюту\"\n\n```\ncur_parse.py:\n```py\nimport requests\n\ndata = requests.get('https://www.cbr-xml-daily.ru/latest.js').json()\n\ndata = data[\"rates\"]\ndata.update({'RUB': 1.0})\n\nval_lst = data.keys()\nprint(val_lst)\n\ncur_from = input('Выберете валюту, из которой вы конвертируете: ').upper()\nval_from = float(input('Введите кол-во валюты: '))\ncur_to = input('Выберете валюту, в которую конвертируете: ').upper()\n\nresult = (data[cur_to]/data[cur_from])*val_from\n\nprint(f'{result:.6g} {cur_to}')\n\n```\ndb.py:\n```py\nimport sqlite3\n\n\nclass DB:\n    def __init__(self, db_name):\n        self.connect = sqlite3.connect(db_name)\n        self.cursor = self.connect.cursor()\n        self.do(\"\"\"\nCREATE TABLE IF NOT EXISTS user (\n    id INTEGER PRIMARY KEY,\n    name TEXT,\n    state INTEGER DEFAULT 0,\n    data TEXT,\n    date DATETIME DEFAULT CURRENT_TIMESTAMP\n    );\"\"\")\n\n    def do(self, query: str, values=()) -\u003e None:\n        self.cursor.execute(query.replace('%s', '?'), values)\n        self.connect.commit()\n\n    def read(self, query: str, values=(), one=False) -\u003e tuple:\n        self.cursor.execute(query.replace('%s', '?'), values)\n        return self.cursor.fetchall() if not one else self.cursor.fetchone()\n\n    def user_exists(self, user_id: int) -\u003e bool:\n        return bool(self.read('SELECT id FROM user WHERE id = ?;', (user_id,)))\n\n    def add_user(self, user_id: int, user_name: str):\n        self.do('INSERT INTO user(id, name) VALUES(?, ?);', (user_id, user_name))\n\n    def set_state(self, user_id: int, state: int) -\u003e None:\n        self.do('UPDATE user SET state = ? WHERE id = ?;', (state, user_id))\n\n    def state(self, user_id: int) -\u003e bool:\n        return self.read('SELECT state FROM user WHERE id = ?;', (user_id,), one=True)[0]\n\n    def set_data(self, user_id: int, data: str) -\u003e None:\n        self.do('UPDATE user SET data = ? WHERE id = ?;', (data, user_id))\n\n    def get_data(self, user_id: int) -\u003e str:\n        return self.read('SELECT data FROM user WHERE id = ?;', (user_id,), one=True)[0]\n\n\n```\nmain.py:\n```py\nimport requests\nfrom aiogram import executor\nfrom cnf import *\n\n\n@dp.message_handler(commands=['start'])\nasync def start(message: types.Message):\n    if not sql.user_exists(message.from_user.id):\n        sql.add_user(message.from_user.id, message.from_user.username)\n\n    await message.answer(start_, parse_mode='MarkdownV2')\n\n@dp.message_handler(commands=['c', 'cur', 'currency'])\nasync def cur(message: types.Message):\n    await message.answer('Выберете *валюту*, из которой вы конвертируете: ', reply_markup=cur_(f_t='_'), parse_mode='MarkdownV2')\n    sql.set_state(message.from_user.id, 1)\n\n@dp.callback_query_handler(lambda call: sql.state(call.from_user.id) == 1)\nasync def cur_from(call: types.CallbackQuery):\n    sql.set_data(call.from_user.id, call.data.replace('_', ''))\n    await call.message.edit_text('Выберете *валюту*, в которую конвертируете: ', reply_markup=cur_(), parse_mode='MarkdownV2')\n    # await call.message.delete()\n    sql.set_state(call.from_user.id, 2)\n\n@dp.callback_query_handler(lambda call: sql.state(call.from_user.id) == 2)\nasync def cur_to(call: types.CallbackQuery):\n    data = sql.get_data(call.from_user.id)\n    sql.set_data(call.from_user.id, f'{data}_{call.data}')\n    await call.message.edit_text(f'Введите кол\\-во *валюты:*', parse_mode='MarkdownV2')\n    # await call.message.delete()\n    sql.set_state(call.from_user.id, 3)\n\n@dp.message_handler(lambda message: sql.state(message.from_user.id) == 3)\nasync def get_cur(message: types.Message):\n    try:\n        message.text = float(message.text.split(' ')[0].replace(' ', '').replace(',', '.'))\n    except Exception as e:\n        print(e)\n        await message.answer('Некорректный ввод, попробуйте еще раз')\n        return None\n\n    data = requests.get('https://www.cbr-xml-daily.ru/latest.js').json()\n    data = data[\"rates\"]\n    data.update({'RUB': 1.0})\n    sub_data = sql.get_data(message.from_user.id)\n    sub_data = sub_data.split('_')\n    result = (data[sub_data[1]] / data[sub_data[0]]) * message.text\n    await message.answer(f'`{message.text}` {sub_data[0]} \\= `{result:.6g}` {sub_data[1]}', parse_mode='MarkdownV2')\n\nif __name__ == \"__main__\":\n    executor.start_polling(dp, skip_updates=True)\n\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flixelv%2Fcur-convert-bot","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flixelv%2Fcur-convert-bot","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flixelv%2Fcur-convert-bot/lists"}