Takže i když to nemusí být moudré nebo škálovatelné, ano, můžete to udělat. Zkuste tento kód:
<?php
$url = "https://spreadsheets.google.com/pub?hl=en&hl=en&key=0AupgXsRU8E9UdC1DY0toUUJLV0M0THM4cGJTSkNSUnc&output=csv";
$row=0;
if (($handle = fopen($url, "r")) !== FALSE) {
while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
$num = count($data);
echo "<p> $num fields in line $row: <br /></p>\n";
$row++;
for ($c=0; $c < $num; $c++) {
echo $data[$c] . "<br />\n";
}
}
fclose($handle);
}
V podstatě publikujte tabulku jako veřejnou, změňte výstup na csv (z výchozího HTML) ruční úpravou adresy URL (tj. output=csv
), načtěte jej a poté jej iterujte řádek po řádku pomocí fgetcsv
.
Pokud tabulka vypadá takto:
Tím se pro příslušný csv zobrazí následující:
array(2) {
[0]=>
string(4) "Name"
[1]=>
string(5) "Value"
}
array(2) {
[0]=>
string(3) "Foo"
[1]=>
string(5) "13123"
}
array(2) {
[0]=>
string(3) "Bar"
[1]=>
string(3) "331"
}