Как красиво вывести таблицу в консоль ? (Я знаю что

её можно не выводить в консоль, а отобразить в TableWidget, но я хочу отобразить именно в консоле)
query = QSqlQuery(db);
query.exec("SELECT * FROM country;");

row = query.size();
col = query.record().count();

QDebug cout = qDebug().nospace();

for (int i = 0; i < row; i++) {
query.next();
for (int j = 0; j < col; j++)
cout << qPrintable(query.value(j).toString()) << " ";
cout << '\n';
}

12 ответов

43 просмотра
assert- Автор вопроса

Я имел ввиду что нет ли другого способа, кроме как того что я описал ?

assert
Я имел ввиду что нет ли другого способа, кроме как...

На гитхабе где-то видел библиотеку, которая рисует в консоль красивую таблицу из символов

assert- Автор вопроса
Mr.Mait
На гитхабе где-то видел библиотеку, которая рисует...

Я тоже видел, но если не ошибаюсь то там грамоздкая структура

а чем принципиально твой вариант не устраивает?

assert- Автор вопроса
Angry Subst
а чем принципиально твой вариант не устраивает?

Он меня устраивает, просто хотел спросить нет ли лучшего решение этой задачи

assert
Он меня устраивает, просто хотел спросить нет ли л...

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

assert
Он меня устраивает, просто хотел спросить нет ли л...

вот size использовать может не стоит Returns the size of the result (number of rows returned), or -1 if the size cannot be determined or if the database does not support reporting information about query sizes т.е. упоминают, что не все драйвера БД возвращают актуальный size

assert- Автор вопроса
Angry Subst
вот size использовать может не стоит Returns the ...

А что тогда в замен его, если я хочу к примеру указывать колонку по номеру столбца и ряда

assert
А что тогда в замен его, если я хочу к примеру ука...

счетчик можно query = QSqlQuery(db); query.exec("SELECT * FROM country;"); quint8_t columns=query.record().count(); if (query.first()) { quint16 row=0; do { row++; // теперь есть актуальный row ... // твой код по выводу } while (query.next()); } но это не парадигма, если ты уверен, что твоя база возвращает QSqlQuery::size() и ты не предполагаешь переползать на другую базу, в отношении которой есть сомнения, то твой код вполне жизнеспособный

assert- Автор вопроса
Angry Subst
счетчик можно query = QSqlQuery(db); query.exec("...

А в каком случае БД не вернёт size ? Как я понимаю то это произойдёт тогда когда в ней ничего нет ?

assert
А в каком случае БД не вернёт size ? Как я понимаю...

ну я же цитату привел кьютовцы упоминают косвенно, что не все БД на это способны

assert
А в каком случае БД не вернёт size ? Как я понимаю...

в моем примере row++ перемети в конец цикла do, если будешь юзать в блокноте писал, косячнул, в сообщении своем щас поправлю

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта