digitalstars/google-sheets

Library for easy work with google-sheets

v1.0.2 2021-08-24 21:34 UTC

This package is auto-updated.

Last update: 2024-10-25 04:06:32 UTC


README

Библиотека для удобной работы с гугл таблицами с использованием Service Account Библиотека имеет зависимость от https://github.com/googleapis/google-api-php-client

Установка

composer require digitalstars/google-sheets

У библиотеки есть баг(issue), что с первого раза не отрабатывает какой-то очищающий скрипт. Поэтому команду установки нужно выполнить 2 РАЗА!!, иначе не появится vendor/autoload.php

Перед началом работы

  1. Вот по этому гайду создаете .json конфиг и почту сервисного аккаунта
$spreadsheet_id = '1FpDbHUknChjWzioeTrddMur-d_tSl7E_-tKCqn9xW6o';
$config_path = 'fire-322212-c5306b491ecc.json';
  1. Заходите в гугл таблицу и выдаете сервисной почте права редактора

Примеры работы

Подключение

<?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); //устанавливаем обратно если надо