Форум программистов, компьютерный форум, киберфорум
Python: API, боты
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 20.07.2021
Сообщений: 16
Discord Bot

Внесение текста в базу данных sqlite3 командой

22.10.2021, 20:51. Показов 2627. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import discord, sqlite3, colorama, termcolor, asyncio
from colorama import Fore, Back, Style
from discord.ext import commands
from config import settings
from asyncio import sleep
from termcolor import colored
 
client = commands.Bot(command_prefix = settings['PREFIX'], intents = discord.Intents.all())
client.remove_command('help')
 
connection = sqlite3.connect('server.db')
cursor = connection.cursor()
 
color_о = colored('[!] ', 'red')
color_i = colored('[i] ', 'yellow')
color_u = colored("[+] ", 'green')
color_cj = colored("[?] ", 'cyan')
 
@client.event
async def on_ready():
    print('')
    print(color_i + 'BadLands')
    await sleep(1)
    print(color_u + 'Bot READY for work!')
    await sleep(1)
    print(color_i + 'dev by qoooki & TayJ')
    await sleep(1)
    print(color_i + 'ver 1.2')
    print('')
 
    while True:
        await client.change_presence(status=discord.Status.online,activity=discord.Game("[+] !help"))
        await sleep(5)
        await client.change_presence(status=discord.Status.online,activity=discord.Game("[i] dev by qoooki"))
        await sleep(5)
        await client.change_presence(status=discord.Status.online,activity=discord.Game("[i] dev by TayJ"))
        await sleep(5)
 
    cursor.execute("""CREATE TABLE IF NOT EXISTS users (
        name TEXT,
        id INT,
        cash BIGINT,
        rep INT,
        lvl BIGINT,
        cred BIGINT,
        nickname TEXT
    )""")
    connection.commit()
 
    for guild in client.guilds:
        for member in guild.members:
            if cursor.execute(f"SELECT id FROM users WHERE id = {member.id}").fetchone() is None:
                cursor.execute(f"INSERT INTO users VALUES ('{member}', {member.id}, 0, 0, 0, 0, 0)") 
            else:
                pass
 
@client.event
async def on_member_join(member):
    if cursor.execute(f"SELECT id FROM users WHERE id = {member.id}").fetchone() is None:
        cursor.execute(f"INSERT INTO users VALUES ('{member}', {member.id}, 0, 0, 0, 0, 0)")
        connection.commit()
    else:
        pass
 
@client.command(aliases = ['reg', 'рег'])
async def __reggg(ctx, member: discord.Member = None, amount = None):
    if amount is None:
        await ctx.send(embed = discord.Embed(description = f"""{ctx.author}, укажите ник. """,color = 0xe74c3c))
    else:
        cursor.execute("UPDATE users SET nickname = nickname + {} WHERE id = {}".format(amount, ctx.author.id))
        connection.commit()
 
        await ctx.message.add_reaction('♥')
 
 
@client.command(aliases = ['карта', 'stats', 'stat', 'balance', 'bal', 'rp', 'roleplay', 'pass', 'card'])
@commands.cooldown(1, 5, commands.BucketType.user)
async def __roleplay(ctx, member: discord.Member = None):
    if member is None:
        await ctx.send(embed = discord.Embed(
            description = f"""<:papers:879334221297090590>  Ваша cтатистика
            **»** Ник: **{cursor.execute("SELECT nickname FROM users WHERE id = {}".format(ctx.author.id)).fetchone()[0]}**
 
            **»**  <:RPcoins:879335435900440587>┃РП очки: **{cursor.execute("SELECT cash FROM users WHERE id = {}".format(ctx.author.id)).fetchone()[0]}**
            
            **»**  <:golden_cup:879333232758382652>┃Репутация: **{cursor.execute("SELECT rep FROM users WHERE id = {}".format(ctx.author.id)).fetchone()[0]}**
            
            **»**  <:ar:878999046549819402>┃Кредит: **{cursor.execute("SELECT cred FROM users WHERE id = {}".format(ctx.author.id)).fetchone()[0]}**
            
            **»**  <:money:879345981206953996>┃Банковский баланс: **{cursor.execute("SELECT lvl FROM users WHERE id = {}".format(ctx.author.id)).fetchone()[0]}** ар.""", color=0x1abc9c))
    else:
        await ctx.send(embed = discord.Embed(
            description = f"""<:papers:879334221297090590>  **{member}** cтатистика
 
            **»**  <:RPcoins:879335435900440587>┃РП очки: **{cursor.execute("SELECT cash FROM users WHERE id = {}".format(member.id)).fetchone()[0]}**
            
            **»**  <:golden_cup:879333232758382652>┃Репутация: **{cursor.execute("SELECT rep FROM users WHERE id = {}".format(member.id)).fetchone()[0]}**
            
            **»**  <:ar:878999046549819402>┃Кредит: **{cursor.execute("SELECT cred FROM users WHERE id = {}".format(member.id)).fetchone()[0]}**
            
            **»**  <:money:879345981206953996>┃Банковский баланс: **{cursor.execute("SELECT lvl FROM users WHERE id = {}".format(member.id)).fetchone()[0]}** ар.""", color=0x1abc9c))
 
 
client.run(settings['TOKEN'])
Надо сделать так, что бы при вводе команды !reg текст - вносился как раз таки этот текст в базу данных в столбец nickname, я его создал, но не работало ничего, помогите пожалуйста!
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.10.2021, 20:51
Ответы с готовыми решениями:

Распознание и внесение текста в базу данных
Здравствуйте, передо мной стоит задача написать программу, которая должна распознавать текст с изображения счет-фактуры, затем распознанный...

внесение данных в базу
люди добрые помогите начинающему , немогу сформировать запрос к базе чтобы внести в нее данные из рег.фомы форма &lt;form...

Внесение данных в базу
Всем доброго времени суток. Помогите пожалуйста начинающему, нужно id полученный методом GET записать в базу вместе с остальными данными...

3
296 / 120 / 33
Регистрация: 06.03.2016
Сообщений: 453
23.10.2021, 12:13
MaksymTer, что за муть тут написана?
SQL
1
... SET nickname = nickname + {} ....
Строковые значения беруться в '
SQL
1
... SET nickname = '{}' ....
0
0 / 0 / 0
Регистрация: 20.07.2021
Сообщений: 16
23.10.2021, 14:47  [ТС]
Сделал как Вы сказали, вписал команду !рег player1, выдало ошибку:
discord.ext.commands.errors.MemberNotFou nd: Member "player1" not found.
0
296 / 120 / 33
Регистрация: 06.03.2016
Сообщений: 453
23.10.2021, 14:57
Лучший ответ Сообщение было отмечено MaksymTer как решение

Решение

MaksymTer,
T-SQL
1
UPDATE users SET nickname = nickname + {} WHERE id = {}
Дословно: установить в строке таблицы users полю nickname значение, где id равно значение.
T-SQL
1
2
3
4
    cursor.execute("""CREATE TABLE IF NOT EXISTS users (
        name TEXT,
        id INT,
        nickname TEXT
Смотрим на таблицу и запрос выше.
id - число. Так с чего бы это должно вообще что-то найти по player1?
Если ищете по id, то и передавайте число.
Если ищите по name, значит ищите по name
T-SQL
1
2
UPDATE users SET nickname = 'supernickname' WHERE id =5
UPDATE users SET nickname = 'supernickname' WHERE name ='player1'
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.10.2021, 14:57
Помогаю со студенческими работами здесь

закодировать базу данных SQLite3
в sqlite3.db сохраняется прогресс игры, можно ли как то его закодировать? чтобы не могли изменять базу данных.

Внесение изменений в базу данных
Доброй ночи, уважаемые форумчане Пишу небольшое приложение и возникла проблема с внесением изменений в БД. public...

Внесение изменений в базу данных
Добрый день, уважаемые пользователи. Столкнулся с проблемой: подключил базу данных SQLite и выгрузил данные в datagrid, все исправно...

Внесение изменений в базу данных
В общем проблема в следующем. Есть форма в c# создания договора. И из таблицы недвижимость(по коду недвижимости)вводим в форму заполнения...

Внесение массива в базу данных
У меня есть массив, возникает вопрос каким образом его затащить в базу. Добавлено через 9 минут тема закрыта, допер)


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Программный отбор элементов справочника Номенклатура по группе 1С
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор под наименованию группы (на. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор элементов справочника Сотрудники по перечислениям 1С
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru