Разрыв страницы в word php
Я не могу найти согласованный метод для создания разрыва страницы, который будет работать в word, internet explorer и chrome.
после возиться со словом я обнаружил, что вы можете получить слово, чтобы добавить разрыв страницы с следующий:
проблема здесь в том, что internet explorer также видит это как разрыв страницы, поэтому, если вы объедините методы, Chrome и Word имеют разрывы страниц правильно, но Internet Explorer вставляет два разрыва страницы. Если вы используете только один, то chrome и explorer правы, а word нет и так далее.
Это соответствует вашим потребностям? (Обратите внимание, что они работают в обычном старом html. Я тестировал в Chrome и MS Word (вместе с IE), и они работали нормально.)
это разница между IE8 и IE9 (при условии, что IE9 находится в стандартном режиме), поэтому вам нужно как - то различать эти браузеры-либо с условным комментарием, либо с помощью CSS-Хака, такого как это:
(протестировано в Chrome, Firefox, OpenOffice Writer [надеюсь, адекватная замена Word] и IE 7,8,9)
для защиты от браузеров, которые применяют разрывы страниц на br и понимают :нет, вы можете добавить это, хотя я не знаю ни одного браузер, который нуждается в этом:
поместите соответствующий CSS !Т. е. условные комментарии. Все остальное можно оставить как есть.
Explorer обрабатывает все между <!--[if !IE]> и <![endif]--> теги как комментарии и Word не будут реагировать на это. Все остальные браузеры будут по-прежнему отображаться.
пользователь, который может просматривать и печатать отчет с помощью Word, также имеет IE и, скорее всего, имеет легкий доступ к Chrome. Поэтому я предполагаю, что Word предназначен не только для просмотра и печати, но и для редактирования.
Я последовал вашему примеру, и мой (немодифицированный во всех аспектах) IE9 не будет печатать разрывы страниц, вставленные с помощью Word 2010 и полученный HTML-документ вряд ли имеет какое-либо сходство с первоначальным, особенно DIVs исчезли, поэтому, предполагая, что документ все еще печатает то же самое после того, как Word сказал свое слово, почти небрежно оптимистично.
вся эта идея кажется сломанной:
- написание HTML ваш путь кажется бессмысленным, учитывая, что слово делает с ним
- даже недавний IE не может обработать ваш простой пример с разрывами страниц, вставленными с помощью Word
- при сохранении Word создал языковая настройка конкретного каталога и три новых файла, которые порождают нелепый большой хост необходимых тестов для любого продукта
- много знаний пользователя (нерестовые каталоги, как правильно сохранить, Как правильно скопировать весь документ), кажется, требуется, чтобы сделать эту работу даже в статической экологической системе Microsoft
- похоже, пользовательские настройки могут легко сломать любое решение, использующее HTML
Я бы предложил сначала написать свой отчет как документ Word. Несмотря на сжатие, документы Word по-прежнему являются разметкой, такой как HTML, поэтому, если вы уже можете генерировать HTML, вы можете генерировать Word без особых усилий. Поскольку вы можете получить Word viewers практически для каждого x86 или ARM-устройства, которое кажется более разумным направлением, чем исследование в направлении, где даже простые примеры терпят неудачу.
еще одно дополнение, которое может быть полезно некоторым людям, обрабатывающим этот тип проблемы: изменение применяется только к элементу блока. В нашем старом тесте кто-то закодировал блок, используя "span". Я тестировал несколько раз и не мог заставить решение Vreality работать. Тогда я подумал, может быть, это потому, что span не является элементом блока, поэтому добавьте "display: block" в элемент, который по умолчанию не является элементом блока.
другое дело: я использую последний Chrome (V. 25), " разрыв страницы внутри: избегайте; " исправление, кажется, больше не нужно.
На момент написания данной статьи релиз PHPWord датируется 8 июля 2011 года. Да еще бета версия. Конечно старовата, но с другой стороны, если класс хорошо выполняет поставленную задачу, то почему бы и нет?!
К делу: скачиваем, подключаем обычным инклюдом и вперед.
Создаем экземпляр класса:
Необязательно, но можем добавить, что по-умолчанию используем шрифт Arial размером 14 пунктов.
Добавляем новый раздел в документ:
$section = $PHPWord->createSection([array $sectionStyle]);
По-умолчанию этот метод создает страницу A4 книжной ориентации. Поля: по 2,5 см верхнее, левое и правое и 2 см нижнее.
Массив $sectionStyle может содержать:
$sectionStyle = array(
'orientation' => 'landscape', // альбомная ориентация страницы
'marginTop' => '0', // по-умолчанию равен 1418* и соответствует 2,5 см отступа сверху
'marginLeft' => '0', // по-умолчанию равен 1418* и соответствует 2,5 см отступа слева
'marginRight' => '0', // по-умолчанию равен 1418* и соответствует 2,5 см отступа справа
'marginBottom' => '0', // по-умолчанию равен 1134* и соответствует 2 см отступа снизу
'pageSizeW' => '8419', // по-умолчанию равен 11906* и соответствует 210 мм по ширине
'pageSizeH' => '11906', // по-умолчанию равен 16838* и соответствует 297 мм по высоте
'borderColor'=>'999999', // Цвет ненужного бордюра
'borderSize'=>'100', // Ширина ненужного бордюра*
);
* В качестве единиц измерения тут используются типографские твипы. Для справки: 1 твип равен 1/567 см.
Текст
У нас есть пустая страница. Для начала добавим обычную текстовую строку. Для этого существует метод addText() и два синтаксиса:
$section->addText(string $text[, array $textStyle]);
// или
$section->addText(string $text[, string $fontStyleName[, string $paragraphStyleName]]);
На практике выглядит это так:
$section->addText('Создание сайтов — Лаборатории WEB');
Тут стоит сделать замечание: автор PHPWord решил, что все, кто будет пользоваться его классом будут работать в кодировке отличной от UTF-8. Если просматривать код PHPWord, то там везде, как через мясорубку, все текстовые переменные проходят через utf8_encode(). Вот в моем случае это сыграло не на руку, потому что я как раз-то работаю с UTF-8.
Что делать, если вы тоже работаете с UTF-8? Варианта как минимум два:
- перед тем как отдать строки в PHPWord измените их кодировку на не UTF-8 с помощью iconv();
- прошерстите PHPWord и удалите все utf8_encode() оттуда.
Мной был выбран второй вариант.
Двигаемся дальше. Наведем «красоту» в тексте.
Первый вариант — это объявление всякой «красоты» непосредственно в методе addText().
$section->addText('Разработка сайтов — Лаборатория WEB', array(
'name' => 'Tahoma',
'color' => '990000',
'bold' => true,
'italic' => true,
'size' => 16,
));
Второй вариант — объединение набора «красот» в стиль.
$PHPWord->addFontStyle('fStyle', array(
'name' => 'Tahoma',
'color' => '990000',
'bold' => true,
'italic' => true,
'size' => 16,
));
$section->addText('Изготовление сайтов — Лаборатория WEB', 'fStyle');
Сейчас был задан стиль для шрифта, но можно задать стиль и для параграфа:
$PHPWord->addParagraphStyle('pStyle', array(
'align' => 'center',
'spaceBefore' => 100, // отступ сверху
'spaceAfter' => 100, // отступ снизу
'spacing' => 100, // межстрочный интервал
));
И использовать эти стили как совместно, так и по-отдельности:
$section->addText('Поддержка сайтов — Лаборатория WEB', 'fStyle', 'pStyle');
// или
$section->addText('Продвижение сайтов — Лаборатория WEB', null, 'pStyle');
Если вам нужно объединить в одном параграфе несколько текстовых блоков с разным форматированием, то для этого существует метод createTextRun():
$textrun = $section->createTextRun('pStyle');
$textrun->addText('Жирный', array(
'bold' => true
));
$textrun->addText('Курсив', array(
'italic' => true
));
$textrun->addText('Красный', array(
'color'=>'990000'
));
С текстом, вроде, все ясно. Перенос курсора на следующую строку:
$section->addTextBreak([int $number]); // В скобках указывается количество строк на которое нужно перейти. По-умолчанию $number = 1
Изображения
Изображения вставляются также просто, как и текст. Для этого используется метод addImage():
$section->addImage(string $srcLocalImage[, array $imageStyle]);
Массив $imageStyle может содержать:
$imageStyle = array(
'width' => '200', // в пикселях
'height' => '200', // в пикселях
'align' => 'center', // left || right || center
)
На практике это выглядит так:
Ссылки
Метод для добавления ссылки addLink ():
$section -> addLink ( string $url , [ string $text [ , string $linkFontStyle [ , string $paragraphStyle ] ] ] ) ;
Наведение «красоты» для ссылки:
На практике это выглядит:
Таблицы
С таблицами немного сложнее. Для добавления таблицы на страницу используем метод addTable(). Как и в случае с текстом, для таблиц существует два синтаксиса. Первый выглядит так:
Массив $tableStyle может содержать:
$tableStyle = array(
'cellMarginTop' => 0, // отступ от ячейки сверху *
'cellMarginRight' => 0, // отступ от ячейки справа *
'cellMarginBottom' => 0, // отступ от ячейки снизу *
'cellMarginLeft' => 0, // отступ от ячейки слева *
);
cellMarginTop, cellMarginRight, cellMarginBottom, cellMarginLeft можно заменить одним cellMargin.
$table = $section->addTable([string $tableStyleName]);
Для того, чтобы назначить $tableStyleName, вызовем метод addTableStyle():
$PHPWord->addTableStyle(string $styleName, array $tableStyle[, array $firstRowTableStyle]);
Как можно понять из названия, массив $firstRowTableStyle отвечает за стили первой строки таблицы.
$word->addTableStyle('tStyle', array(
'borderSize' => 6,
'borderColor' => '999999',
'cellMarginTop' => 40,
'cellMarginRight' => 20,
'cellMarginBottom' => 40,
'cellMarginLeft' => 20,
), array(
'borderSize' => 12,
'borderColor' => '000000',
'cellMargin' => 80,
));
$table = $section->addTable('tStyle');
Тут мы назначили для ячеек всей таблицы ширину границы 6, цвет серый, с отступами 40 20 40 20. А для ячеек первой строки ширину границы 12, черного цвета с отступами 80 со всех сторон.
Теперь в таблицу нужно добавить строку. Для этого существует метод addRow ():
$table->addRow([int $rowHeight]); // $rowHeight — высота строки в твипах
И методом addCell () добавляем ячейку:
$cell = $table->addCell(int $cellWidth[, array $cellStyle]);
Здесь $cellWidth — ширина ячейки в твипах, а массив $cellStyle может содержать:
$cellStyle = array(
'valign' => 'center', // top || bottom || center || both
'textDirection' => PHPWord_Style_Cell:TEXT_DIR_BTLR, // PHPWord_Style_Cell:TEXT_DIR_BTLR || PHPWord_Style_Cell:TEXT_DIR_TBRL
'bgColor' => 'fafafa',
'borderTopSize' => 6,
'borderRightSize' => 6,
'borderBottomSize' => 6,
'borderLeftSize' => 6,
'borderSize' => 6, // вместо borderTopSize, borderRightSize, borderBottomSize, borderLeftSize
'borderTopColor' => '999999',
'borderRightColor' => '999999',
'borderBottomColor' => '999999',
'borderLeftColor' => '999999',
'borderColor' => '999999', // вместо borderTopColor, borderRightColor, borderBottomColor, borderLeftColor
);
Последнее, что нужно сделать — это добавить содержимое в новую ячейку (добавим текст). Сделать это можно двумя способами:
$cell = $table->addCell();
$cell->addText('Создание Langing Page — Лаборатория WEB');
// или
$table->addCell()->addText('Разработка Langing Page — Лаборатория WEB');
Списки
Добавление на страницу нумерованных и ненумерованных списков осуществляется методом addListItem():
$section->addListItem(string $text[, int $depth[, string $textStyle[, array $listStyle[, string $paragraphStyle]]]]);
Здесь $depth — глубина (вложенность) списка от 1 до 9, а массив $listType может состоять из:
$listType = array(
'listType' => PHPWord_Style_ListItem:TYPE_NUMBER, // одноуровневый нумерованный список
);
Также параметр 'listType' может принимать следующие значения:
- PHPWord_Style_ListItem:TYPE_NUMBER_NESTED — многоуровневый нумерованный список;
- PHPWord_Style_ListItem:TYPE_BULLET_FILLED — ненумерованный список с маркерами в виде закрашенных кругов;
- PHPWord_Style_ListItem:TYPE_BULLET_EMPTY — ненумерованный список с маркерами в виде незакрашенных кругов;
- PHPWord_Style_ListItem:TYPE_SQUARE_FILLED — ненумерованный список с маркерами в виде закрашенных квадратов.
Колонтитулы
При работе с колонтитулами нужно помнить, что они привязываются к разделу и выглядят одинаково на всех страницах, относящихся к одному и тому же разделу.
Создадим верхний и нижний колонтитулы и добавим в них содержимое:
Метод addPreserveText() существует специально для добавления номеров страниц.
Разное
$meta = $PHPWord->getProperties();
$meta->setTitle('Название');
$meta->setSubject('Тема');
$meta->setCreator('Автор');
$meta->setCompany('Учреждение');
$meta->setDescription('Заметки');
$meta->setCategory('Группа');
$meta->setLastModifiedBy('Автор изменений');
$meta->setKeywords('Ключевые слова');
$meta->setCreated(time()); // Дата и время создания документа
$meta->setModified(time()); //Дата и время последнего изменения документа
Библиотека PHPWord, находящаяся уже почти год в стадии бета-тестирования 1) , предоставляет возможность создания сложных документов формата OOXML (*.docx). Рассмотрим основные возможности этой библиотеки. Для начала работы достаточно распаковать архив с библиотекой в каталог с создаваемым вами документом PHP и подгрузить основной класс библиотеки, расположенный в файле PHPWord.php:
Свойства документа и шрифт по-умолчанию
Создание документа начинается с объявления экземпляра класса PHPWord. Конструктор не требует передачи аргументов:
Далее следует задать название и размер шрифта по-умолчанию:
В рассматриваемой версии до применения указанных выше функций шрифтом по-умолчанию является Arial размером 20 пунктов. Теперь можно задать время создания документа, имя автора и так далее:
По-умолчанию в качестве даты создания и изменения документа указывается текущее время, а остальные свойства заполняются пустыми значениями. Если требуется указать конкретную дату создания или изменения, используйте функцию mktime или любую другую функцию, возвращающую время в стиле Unix.
Создание разделов
Основным элементом документа Word является Раздел. Раздел представляет собой прямоугольную область, внутри которой помещаются остальные элементы страницы: текст, изображения, таблицы и т.д.
Раздел может иметь книжную или альбомную ориентацию, настраиваемые поля (margins), настраиваемые цвета границ раздела и их толщину (на рисунке показана пунктиром):
Для создания раздела существует функция createSection. В качестве внутренних единиц используются типографские твипы. Если вам непривычно указывать размеры в твипах, можно написать простую функцию, преобразующую миллиметры в твипы:
Указанные в таблице параметры могут быть переданы в виде массива при создании раздела.
. или могут быть установлены по-отдельности после создания раздела:
Добавление текста
Добавление блока текста
Под блоком текста понимается отрывок текста, имеющий одинаковое форматирование (цвет, размер шрифта и т.п.). Для создания блока текста в выбранном разделе используйте функцию addText:
Изменение форматирования текста
Форматирование текста, как и форматирование раздела, может осуществляться при его создании.
. или устанавливается после создания предназначенными для этого методами:
Ниже приведен полный список доступных параметров форматирования текста:
Названия параметров должны употребляться с соблюдением регистра. В случае параметров underline и fgColor применение значений, не указанных в таблице, не допускается.
Cписок доступных параметров форматирования абзаца:
Определение стилей текста и абзаца
Вместо того, чтобы каждый раз передавать в функцию createText массив с параметрами, вы можете создать именованный стиль, а затем указывать только название этого стиля:
Аналогичным образом осуществляется создание стиля абзаца:
Группировка блоков текста в абзац
Блоки текста с различным форматированием могут быть объединены в абзац заданного вида. Для этого применяется команда createTextRun:
Добавление заголовков
В библиотеке имеются отдельные функции для добавления заголовков (addTitle) и задания их стилей (addTitleStyle). Применение заголовков вместо форматированных блоков текста необходимо в том случае, если вы хотите добавить в документ автоматически создаваемое оглавление, поскольку в оглавление включаются только заголовки, а не обычные блоки текста. При добавлении заголовков создание стилей заголовков обязательно:
По-умолчанию создается заголовок 1 уровня.
Добавление ссылок
Добавление ссылок мало чем отличается от добавления обычного текста. Для добавления ссылки используется команда:
Разрыв строки и страницы
Для принудительного переноса строки используйте синтаксис:
Необязательный параметр $num, по-умолчанию равный 1, указывает сколько переносов строки необходимо сделать. Для принудительной вставки разрыва страницы выполните:
Добавление оглавления
Для добавления оглавления используется функция addTOC:
Добавление списков
Присутствует возможность добавления нумерованных и ненумерованных списков в документ. Для добавления элемента списка используйте код:
Добавление таблиц
Важной частью документа Word являются таблицы. Для создания таблицы в PHPWord выполните:
cellMarginTop | Отступ от ячейки сверху в твипсах |
cellMarginRight | Отступ от ячейки справа в твипсах |
cellMarginBottom | Отступ от ячейки снизу в твипсах |
cellMarginLeft | Отступ от ячейки слева в твипсах |
Теперь в созданную таблицу можно добавить ячейки. Как и в XHTML, вначале нужно создать строку.
. затем добавить ячейки и заполнить их форматированным текстом.
. или сделать то же самое одной командой.
. или вместо простого текста добавить изображения, списки ссылки одной из следующих команд:
Команда | Действие |
---|---|
addText | Добавить форматированный текст |
addTextBreak | Добавить перенос строки |
addLink | Добавить ссылку |
addListItem | Добавить элемент списка |
addImage | Добавить изображение из файла |
addMemoryImage | Добавить динамически сгенерированное изображение |
addObject | Добавить объект OLE |
addPreserveText | Добавить поле (например, нумерацию страниц) |
Добавление изображений
PHPWord позволяет добавлять в создаваемый документ изображения 2 типов: из файла (метод addImage) и динамически сгенерированное сценарием изображение (метод addMemoryImage). Поддерживаются файлы форматов jpg, png, gif, tiff, bmp. Примеры применения методов:
Добавление объектов OLE
С помощью метода addObject вы можете внедрить в создаваемый документ фрагмент другого документа (*.docx, *.xlsx, *.pptx) при помощи технологии OLE:
Массив $objectStyle может содержать только один параметр:
Колонтитулы
Каждый раздел документа может иметь свой верхний (header) и нижний (footer) колонтитул, отображаемый на всех принадлежащих ему страницах. С точки зрения Word колонтитул является особым видом раздела, поэтому к колонтитулу применимо большинство описанных выше методов: addText, createTextRun, addTextBreak, addImage, addMemoryImage, addListItem, addTable. Кроме этого колонтитул имеет собственный метод addPreserveText, позволяющий создавать нумерацию страниц. Пример создания верхнего (createHeader) и нижнего (createFooter) колонтитула:
Как и всегда форматирование текста колонтитула и абзаца являются необязательными параметрами.
Использование шаблонов
Сохранение файла
Сохранение файла на жесткий диск:
Пример
Подытоживая все вышесказанное хочется привести пример, в котором проиллюстрировано применение большинства возможностей библиотеки PHPWord:
Данный пример в работе можно посмотреть по этой ссылке. В заключение хотелось бы отметить, что для сайтов, где структура docx-файла слабо 4) зависит от входных данных, рекомендуемым способом стоит считать docx-templates, поскольку:
Шаблон договора для phpWord
Начну с постановки задачи. А она довольно простая — работая над сайтом клиента по прокату автомобилей возникла необходимость несколько автоматизировать рутинные операции. В частности требовалось при оформлении аренды на сайте автоматически заполнять в договоре некоторые поля. Вот этим и займемся.
Для работы нам потребуется замечательная библиотека phpWord. Она имеет огромное количество возможностей, мы же рассмотрим ее способность заполнять готовые шаблоны документов.
Итак, мы скачали phpWord, распаковали архив и залили на веб-сервер. В моем случае речь идет о версии 0.6.2 Beta.
phpWord заливка на сервер
Теперь нам необходимо подготовить сам шаблон. Для этого запускаем MS Word или даже Wordpad и набираем текст договора. Для примера я набросал тестовый договор, который выглядит вот так (кликабельно):
Давайте определимся, что в этом шаблоне мы поручим заполнять php скрипту. К примеру, пусть это будет номер договора с датой, а также ФИО продавца и номер паспорта. Теперь давайте превратим наш договор в шаблон, с которым будем работать дальше.
Итак, для заполнения мы определили данные, давайте подберем для них имена. Это может быть транслитерация или английское написание, вы можете выбрать по вкусу.
Данные | Переменная |
Номер договора | d_num |
Дата договора | d_date |
Фамилия | last_name |
Имя | name |
Отчество | surname |
Замечательно. Теперь делаем следующее — на тех местах, где у нас данные, мы их удаляем и вставляем имена переменных в виде
Т. е. там, где у нас номер договора 123 мы пишем $ и т. д. для всех переменных. В итоге получится вот такой шаблон договора:
Шаблон договора для phpWord
Отнеситесь к этому внимательно — ошибок допускать нельзя. Сохраняем полученный шаблон под именем Template.docx (можно назвать по своему).
Внимание! При сохранении документа в Word 2010 поставьте чекбокс «Поддерживать совместимость с предыдущими версиями Word» иначе работать не будет.
Вот теперь наш шаблон готов, теперь давайте научим php заполнять его.
Создаем php файл (к примеру, index.php) со следующим содержимым:
Вот и все. Если теперь мы запустим выполним наш скрипт, то в итоге получим заполненный данными шаблон договора:
Как видно, скрипт успешно заполнил шаблон, вот только с русскими символами беда — они выглядят не так, как задумывалось. Как решить эту проблему читайте в статье.
На этом все. Надеюсь, что хоть немного помог читателю разобраться с заполнением docx файлов на php. Для изучения все материалы можно скачать в виде архива.
Меток нет. Похожие записи
8 комментариев: Работа с phpWord. Заполнение шаблона договора docx
Спасибо за статью! Много прочитала, но помогла именно ваша
А как быть, чтобы отдать полученный документ на скачивание, а не сохранять на жесткий диск?
Я делаю:
У меня тоже PHP Word на выходе отдает какой-то битый файл, который не открывается в Word. При этом файл не пустой, но почему-то имеет неверный формат. При просмотре файла в Editre- в нем полно всякой ерунды, включая заголовки сайта, меню, куки php. Не знаете в чем проблема? Почему библиотека phpword не работает как надо?
метод saveAs() надо вызвать, тока тогда сохранит изменения
А как вообще эту библиотеку прикрутить к тому же денверу, сказано скиньте в ваш вебсервер, куда уже только не кидал не видит он её. кидал homeдоменwww кидал так же homelicalhost
А процедурным стилем как вносить данные в документ?
Не работает ваш пример.
вот эта строка вызывает подозрения require_once ‘PHPWord.php’; вы хотите подключить файл ‘PHPWord.php’ которого нет,среди скачанных файлов, что вообще за бред? зря только время потратил.
А скачать по самой первой ссылке что мешает?
Общее замечание. Статья относится к библиотеке 2011 года PHPWord. Она была такая, и исходники есть, и всё так. На гитхабе сейчас лежит её далёкий потомок PhpWord. В нём изменено очень много чего (например, не надо кривить исходники ради корректной работы с русским языком). И, в частности, пример выглядит радикально по-другому:
Думаю, это замечание (о наличии новой версии либы с новыми вызовами) надо добавить в описание. Кому что удобнее: свежая либа с композером и хреновой горой пхпового мусора, или старая, но с багами, пусть решает сам.
dixi
Дата публикации: 2016-02-25
От автора: не так давно на нашем сайте были опубликованы уроки по работе с таблицами Microsoft Excel средствами языка PHP, которые вызвали значительный интерес у нашей аудитории и поэтому, сегодня я решил показать Вам, как создавать документы Microsoft Word ,формата .docx, используя мощнейшую библиотеку PHPWord.
Актуальную версию библиотеки PHPWord, вы найдете на сервисе GitHub.
Бесплатный курс по PHP программированию
Освойте курс и узнайте, как создать динамичный сайт на PHP и MySQL с полного нуля, используя модель MVC
В курсе 39 уроков | 15 часов видео | исходники для каждого урока
На данной странице, приведено краткое описание и инструкция по установке библиотеки. Но данная инструкция очень ограничена и не описывает всех возможностей библиотеки, поэтому, официальную PHPWord документацию, для разработчиков, Вы найдете по ссылке.
Установка PHPWord
Установка PHPWord, может быть выполнена двумя способами. Первый способ – ручной, при котором Вы скачиваете архив с последней актуальной версией PHPWord, далее, выполняете распаковку, копируете файлы в собственный проект и подключаете на соответствующих страницах. То есть достаточно стандартный способ. И второй – так сказать, автоматический способ установки, используя инструмент Composer, который мы будем использовать в данном уроке.
Кстати, Вы, наверное, заметили, что в своих уроках, для установки различных библиотек, я призываю Вас использовать Composer. Так как для простых проектов, в ручную, вполне можно скачивать необходимые элементы, но если мы работаем над более сложным скриптом, то порой затруднительно скачать все необходимые элементы и правильно их установить.
Итак, открываем командную строку и переходим в каталог нашего проекта, используя команду “CD имя папки”.
Далее, используя конструкцию “composer require”, указываем от какой библиотеки “зависит” наш проект и выполняем инструкцию.
Читайте также: