digitalstars / google-sheets
Library for easy work with google-sheets
v1.0.2
2021-08-24 21:34 UTC
Requires
- php: >=7.0
- ext-curl: *
- google/apiclient: ^2.10
README
Библиотека для удобной работы с гугл таблицами с использованием Service Account Библиотека имеет зависимость от https://github.com/googleapis/google-api-php-client
Установка
composer require digitalstars/google-sheets
У библиотеки есть баг(issue), что с первого раза не отрабатывает какой-то очищающий скрипт. Поэтому команду установки нужно выполнить 2 РАЗА!!, иначе не появится
vendor/autoload.php
Перед началом работы
- Вот по этому гайду создаете .json конфиг и почту сервисного аккаунта
$spreadsheet_id = '1FpDbHUknChjWzioeTrddMur-d_tSl7E_-tKCqn9xW6o'; $config_path = 'fire-322212-c5306b491ecc.json';
- Заходите в гугл таблицу и выдаете сервисной почте права редактора
Примеры работы
Подключение
<?php require_once 'vendor/autoload.php'; use DigitalStars\Sheets\DSheets; $spreadsheet_id = '1FpDbHUknChjWzioeTrddMur-d_tSl7E_-tKCqn9xW6o'; $config_path = 'fire-322212-c5306b491ecc.json'; $sheet = DSheets::create($spreadsheet_id, $config_path)->setSheet('Лист');
Выгрузка данных
$data = $sheet->get(); //выгрузит все данные в листе print_r($data); // [ // ['id', 'name', 'mail'], // ['1', 'name1', 'mail1'], // ['2', 'name1', 'mail2'] // ] $data = $sheet->setSheet('Лист2')->get('A:A'); //выгрузит весь столбец А из Лист2 print_r($data); // [ // ['id'], // ['1'] // ['2'] // ] $data = $sheet->get('A2:B3'); //выгрузит диапазон A2:B3 print_r($data); // [ // ['1', 'name1'], // ['2', 'name1'] // ]
Добавление в конец листа
Этот метод добавляет данные в конец листа, где встречена пустота
$sheet->append([['Имя', 'Фамилия', 'Возраст']]); //добавит в конец A по максимальной используемой строке всех букв //Если C6-C8 пустые, то добавит в них. Иначе в самый конец A ориентируясь по максимальной используемой строке всех букв $sheet->setSheet('Лист2')->append([['Имя', 'Фамилия', 'Возраст']], 'C6');
Обновление/добавление данных
$sheet->update([['Имя', 'Фамилия', 'Возраст']]); //добавит в A1-C1 $sheet->setSheet('Лист2')->update([['Имя', 'Фамилия', 'Возраст']], 'A3'); //добавит в A3-C3 даже если они заполнены
Использование оригинального Google_Service_Sheets
$service = $sheet->getService(); //получаем $service->spreadsheets->... $service->spreadsheets_sheets->... $service->spreadsheets_values->... $client = $service->getClient(); $sheet->setService($service); //устанавливаем обратно если надо