Парсинг таблицы из Google документов

Просмотров: 3920Комментарии: 0
ПрограммированиеPHP-MySQL
Парсинг таблицы из Google документов

Появилась необходимость вывода данных из таблицы находящейся в аккаунте Google. Документы Google, а именно таблицы, позволяют создавать таблицы, подобные Excel, в режиме онлайн. Допустим мне нужно вывести рейтинг гонщиков из таблицы Google документов.

Мне нужно вывести рейтинг гонщиков из следующей таблицы

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

https://spreadsheets.google.com/spreadsheet/ccc?key=[color=blue]КЛЮЧ[/color]&hl=ru#gid=0

Нам нужно вывести рейтинг на странице [span(label]http://наш сайт/rating.php[/span]

Создаем файл rating.php:

...  // ваш код начала страницы (оформление, метатеги)
echo '<h1>Положение гонщиков на '.$dat.'</h1>'; //Выводим заголовок
//Задаем ссылку получения документа
$myurl = "https://spreadsheets.google.com/spreadsheet/pub?hl=ru&key=КЛЮЧ&single=true&gid=0&output=csv";
// gid - номер страницы; output - тип результата (html/csv)
// подключаем curl
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $myurl);
curl_setopt($curl, CURLOPT_POST, false);
$response = curl_exec($curl);
// $response теперь содержит нашу таблицу в формате csv
curl_close($curl);
// разбиваем по строкам
$res = explode("\n",$response);
echo '<table>';
foreach($res as $row)
{
   //разбивка на столбики
   $row = explode(",",$row);
   echo '<tr>';
   echo '<td>'.$row[0].'</td>';//место
   echo '<td>'.$row[1].'</td>';//имя
   echo '<td>'.$row[3].'</td>';//страна
   echo '<td>'.$row[4].'</td>';//рейтинг
   echo '<td>'.$row[5].'</td>';//за месяц
   echo '</tr>';
}
... // какой-то код

Если требуется аутентификация то вместо строки подключения $curl

$curl = curl_init();

вставляем такой код:

$clientlogin_url = "https://www.google.com/accounts/ClientLogin";
$clientlogin_post = array(
    "accountType" => "HOSTED_OR_GOOGLE",
    "Email" => "ЛОГИН",
    "Passwd" => "ПАРОЛЬ",
    "service" => "writely",
    "source" => "MyGetTable"
);
$curl = curl_init($clientlogin_url);
curl_setopt($curl, CURLOPT_POST, true);
curl_setopt($curl, CURLOPT_POSTFIELDS, $clientlogin_post);
curl_setopt($curl, CURLOPT_HTTPAUTH, CURLAUTH_ANY);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$response = curl_exec($curl);
preg_match("/Auth=([a-z0-9_\-]+)/i", $response, $matches);
$auth = $matches[1];
$headers = array(
    "Authorization: GoogleLogin auth=" . $auth,
    "GData-Version: 3.0",
);
curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
Оставьте комментарий!

grin LOL cheese smile wink smirk rolleyes confused surprised big surprise tongue laugh tongue rolleye tongue wink raspberry blank stare long face ohh grrr gulp oh oh downer red face sick shut eye hmmm mad angry zipper kiss shock cool smile cool smirk cool grin cool hmm cool mad cool cheese vampire snake excaim question

Используйте нормальные имена. Ваш комментарий будет опубликован после проверки.

     

  

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

(обязательно)