Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 26.05.2022
Сообщений: 15

Есть ли способ преобразовать как нибудь php mysql таблицу в Excel ну или в похожий формат?

19.08.2022, 07:08. Показов 631. Ответов 9
Метки php (Все метки)

Студворк — интернет-сервис помощи студентам
есть таблица требуют чтобы её можно было скачать в виде excell таблицы.
Заранее спасибо.
PHP
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
<!doctype html>
<html lang="ru">
<head>
    <meta charset="UTF-8">
 
    <title>Протокол соревнования <?= $p ?>: <?= $w ?>кг</title>
 
 
 
</head>
 
<style>
    table {
 
        width: 1000px;
 
        border-collapse: collapse;
 
        border: 2px solid black;
 
    }
 
    th, td {
        padding: 10px;
        text-align: center;
    }
 
    th {
        background: #606060;
        color: #fff;
        border-collapse: collapse;
 
        border: 2px solid black
    }
 
 
 
 
    td {
 
 
        padding: 3px;
 
        border: 1px solid ;
 
        text-align: center;
 
    }
 
    @media print {
 
        #head {
            display: flex;
        }
        #printableTable {
            display: block;
        }
 
    }
 
</style>
 
<script>
    function printDiv() {
        window.frames["print_frame"].document.body.innerHTML = document.getElementById("printableTable").innerHTML;
        window.frames["print_frame"].window.focus();
        window.frames["print_frame"].window.print();
    }
</script>
<body>
<div id="printableTable" >
    <table >
    <p><?= $d ?></p>
 
    <tr>
        <th colspan="7">Date:<?= $a ?></th>
        <th colspan="30"> <?= $p ?> : <?= $w ?>кг</th>
        <th colspan="5"><?= $c ?>:<?= $b ?></th>
    </tr>
 
    <tr>
        <th rowspan="2">№</th>
        <th rowspan="2">lot</th>
        <th rowspan="2">ФИО</th>
        <th rowspan="2">Вес</th>
        <th rowspan="2">Дата рождения</th>
        <th rowspan="2">Команда</th>
        <th rowspan="2">Разряд</th>
        <th colspan="30">Rounds</th>
        <th rowspan="2">Выбытие</th>
        <th rowspan="2">побед</th>
        <th rowspan="2">поражений</th>
        <th rowspan="2">очков</th>
        <th rowspan="2">Место</th>
    </tr>
    <tr>
 
        <th colspan="3">1</th>
        <th colspan="3">2</th>
        <th colspan="3">3</th>
        <th colspan="3">4</th>
        <th colspan="3">5</th>
        <th colspan="3">6</th>
        <th colspan="3">7</th>
        <th colspan="3">8</th>
        <th colspan="3">9</th>
        <th colspan="3">10</th>
 
    </tr>
    <?php
    $info7 = mysqli_query($conn, "SELECT * FROM `g1`  where `cid` = '$z' AND `gendage` LIKE '$g' AND `wc` = '$w'  ORDER BY `tablo1`.`lot` ASC ");
 
    $info = mysqli_query($conn, "SELECT * FROM `person` INNER JOIN `tablo1` using (id) WHERE `lot` != 0 AND `cid` = '$z' AND `gendage` LIKE '$g' AND `wc` = '$w'  ORDER BY `tablo1`.`lot` ASC ");
 
 
 
    foreach ($info as $info) {
        ?>
        <tr>
            <td rowspan="2"><?= $info["quid"]?></td> <!-- id-->
            <td rowspan="2"><?= $info["lot"]?></td> <!-- id-->
            <td rowspan="2"><?=$info['Name']?></td> <!-- Фио-->
            <td rowspan="2"><?=$info['weight']?></td> <!-- вес-->
            <td rowspan="2"><?=$info['BD']?></td> <!-- год рождения-->
            <td rowspan="2"><?= $info['Team2']?></td>
            <td rowspan="2"><?= $info['ks']?></td><!-- команда-->
            <td rowspan="2"><?= $info['O1']?></td> <!-- противник-->
            <td ><?=$info['R1']?></td> <!-- победа-->
            <td ><?=$info["L1"]?></td> <!-- поражение-->
            <td rowspan="2"><?=$info['O2']?></td>
            <td ><?=$info['R2']?></td>
            <td ><?=$info['L2']?></td>
            <td rowspan="2"><?= $info['O3']?></td>
            <td ><?=$info['R3']?></td>
            <td ><?=$info['L3']?></td>
            <td rowspan="2"><?=$info['O4']?></td>
            <td ><?=$info['R4']?></td>
            <td ><?=$info['L4']?></td>
            <td rowspan="2"><?=$info['O5']?></td>
            <td ><?=$info['R5']?></td>
            <td ><?=$info['L5']?></td>
            <td rowspan="2"><?=$info['O6']?></td>
            <td ><?=$info['R6']?></td>
            <td ><?=$info['L6']?></td>
            <td rowspan="2"><?=$info['O7']?></td>
            <td ><?=$info['R7']?></td>
            <td ><?=$info['L7']?></td>
            <td rowspan="2"><?=$info['O8']?></td>
            <td ><?=$info['R8']?></td>
            <td ><?=$info['L8']?></td>
            <td rowspan="2"><?=$info['O9']?></td>
            <td ><?=$info['R9']?></td>
            <td ><?=$info['L9']?></td>
            <td rowspan="2"><?=$info['O10']?></td>
            <td ><?=$info['R10']?></td>
            <td ><?=$info['L10']?></td>
            <td rowspan="2"><?=$info['PB']?></td> <!-- выбытие-->
            <td rowspan="2"><?=$info['Wins']?></td> <!-- Побед-->
            <td rowspan="2"><?= $info["lose"]?></td> <!-- Поражений-->
            <td rowspan="2"><?= $info['Wins'] - $info['lose']?></td> <!-- Очков-->
            <td rowspan="2"><?= $info['place']?></td> <!-- Очков-->
 
 
 
 
        </tr>
        <tr>
            <td colspan="2"><?=$info['m1']?></td> <!-- счет-->
            <td colspan="2"><?=$info['m2']?></td>
            <td colspan="2"><?=$info['m3']?></td>
            <td colspan="2"><?=$info['m4']?></td>
            <td colspan="2"><?=$info['m5']?></td>
            <td colspan="2"><?=$info['m6']?></td>
            <td colspan="2"><?=$info['m7']?></td>
            <td colspan="2"><?=$info['m8']?></td>
            <td colspan="2"><?=$info['m9']?></td>
            <td colspan="2"><?=$info['m10']?></td>
 
 
 
        </tr>
        <?php
    }
    ?>
    <tr>
        <th colspan="21" >M.Referee: <?= $e ?> referee  <?= $e2 ?> (<?= $e1 ?>)__________</th>
        <th colspan="21">M.Secretary: <?= $f ?> referee  <?= $f2 ?> (<?= $f1 ?>)__________</th>
    </tr>
 
 
    </table>
</div>
<iframe name="print_frame" width="1" height="1" border="0" src="about:blank"></iframe>
 
<a href="#" onclick="window.print();return false;">Распечатать</a>
 
 
 
</body>
</html>
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.08.2022, 07:08
Ответы с готовыми решениями:

Есть ли способ сохранить таблицу из DataTable в mysql
Здравствуйте. Вообщем мне нужно сделать быстрый перенос БД dbf в mysql. При переносе через запросы insertr 200000 записей (а есть табл...

Есть ли какой нибудь хитрый или необычный способ заработать в интернете?
Почти 2 года интересуюсь заработком в интернете и что только не успел попробовать - буксы, файлообменники, казино, установка мобильных...

Как изучать mysql и php? Сначала php, а потом mysql или наоборот, или сразу?
Хочу изучить mysql и php. Как их изучать? Сначала php, а потом mysql или наоборот, или сразу и то и то? Посоветуйте хорошую литературу.

9
23 / 16 / 9
Регистрация: 10.02.2021
Сообщений: 44
19.08.2022, 08:44
Используйте https://github.com/PHPOffice/PhpSpreadsheet
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
19.08.2022, 16:42
Ещё есть https://github.com/box/spout
Меньше кушает, но и функционала поменьше.
0
 Аватар для HotReboot
326 / 227 / 92
Регистрация: 22.04.2017
Сообщений: 1,136
19.08.2022, 18:15
Проще можно в csv загнать
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
function export_csv(
    $table,         // Имя таблицы для экспорта
    $afields,       // Массив строк - имен полей таблицы
    $filename,      // Имя CSV файла для сохранения информации
                // (путь от корня web-сервера)
    $delim=',',         // Разделитель полей в CSV файле
    $enclosed='"',      // Кавычки для содержимого полей
    $escaped='\\',      // Ставится перед специальными символами
    $lineend='\\r\\n'){     // Чем заканчивать строку в файле CSV
 
    $q_export = "SELECT ".implode(',', $afields).
    "   INTO OUTFILE '".$_SERVER['DOCUMENT_ROOT'].$filename."' ".
    "FIELDS TERMINATED BY '".$delim."' ENCLOSED BY '".$enclosed."' ".
    "    ESCAPED BY '".$escaped."' ".
    "LINES TERMINATED BY '".$lineend."' ".
    "FROM ".$table;
 
    // Если файл существует, при экспорте будет выдана ошибка
    if(file_exists($_SERVER['DOCUMENT_ROOT'].$filename)) 
        unlink($_SERVER['DOCUMENT_ROOT'].$filename); 
    return mysql_query($q_export);
}
0
168 / 124 / 42
Регистрация: 25.10.2019
Сообщений: 476
20.08.2022, 03:04
Через консоль.
Возможность есть прямо из коробки.

Но еще проще...
0
168 / 124 / 42
Регистрация: 25.10.2019
Сообщений: 476
20.08.2022, 03:04
Через консоль.
Возможность есть прямо из коробки.

Но еще проще...
Вложение 1363341
0
168 / 124 / 42
Регистрация: 25.10.2019
Сообщений: 476
20.08.2022, 03:12
Через консоль.
Возможность есть прямо из коробки.

Но еще проще...
Вложение 1363341
Документ Excel'я позволяет всё форматнуть в человекопонятный файл.

А еще, Excel позволяет напрямую получить данные из БД. Прямо внутри документа в реальном времени) и даже через API или тупо просто со страницы интернета. (т.е. на php сделали страницу - просто соединили её с доком)

А еще, XML,JSON, txt, csv любой БД

Данные - Получить данные - развлекайтесь =)
0
 Аватар для HotReboot
326 / 227 / 92
Регистрация: 22.04.2017
Сообщений: 1,136
20.08.2022, 06:35
websyst_ru, Жесть. Т.е. как бы не видно, что сначала выводится таблица с кнопкой Распечатать, а значит вся это бодяга на сайте и с него нужно получить файл?
0
168 / 124 / 42
Регистрация: 25.10.2019
Сообщений: 476
20.08.2022, 11:42
HotReboot, Если вы не знаете как повесить всё это на кнопку - могу подсказать.
А если считаете, что есть какая-то разница между отображением данных на странице или другом месте - это не так.

К тому же, SQL обрабатывает команды быстрее, чем php.
0
 Аватар для HotReboot
326 / 227 / 92
Регистрация: 22.04.2017
Сообщений: 1,136
20.08.2022, 21:15
websyst_ru, Ну не позорьтесь пытаясь теперь "выехать". Давайте на сайте кнопку для экспорта php посредством phpmyadmin.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.08.2022, 21:15
Помогаю со студенческими работами здесь

Может есть у кого нибудь похожий исходник по этой статье
http://refleader.ru/jgernajgeyfsaty.html

Создать документ похожий на Excel таблицу с форматированием строк и столбцов
Подскажите,пожалуйста, нужно с помощью C# создать документ похожий на excel табличку. колонки,ячейки и т.д. Но лезть в excel не хочется....

Как максимально быстро вывести данные в таблицу (формат Excel)?
Здравствуйте знатоки. Нужна помощь. Столкнулся с такой проблемой: есть большущая программа, рассчитывающая множество параметров. В...

Есть ли какой-нибудь способ в WPF включить подсказки?
Я только начал изучать WPF. Решил замутить кнопочку в виде эллипсиса с анимации по окантовке. Столкнулся, с тем, что лично для меня не...

Есть какой нибудь способ отобразить логические символы?
в текстовом поле c#? то есть их настоящий вид? к примеру отрицание надчеркивание сверху. умножение- перевернутая V? для этого видимо надо...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru