使用google sheet api V4 with php
google sheet如果不指定範圍就寫append程式只要輸入空格就會發生推移如下
$rangeNOW=’代墊費’;
$values = [[date(‘Y/m/d’),$item, $money, ‘ ‘ ,’努狗巴弟巴弟紀錄’]]
$body = new \Google_Service_Sheets_ValueRange([
‘values’ => $values
]);
$params = [
‘valueInputOption’ => ‘USER_ENTERED’
];
$service->spreadsheets_values->append($spreadsheetId, $rangeNOW, $body, $params);
只要插入新的一行,會從你上一列最後出現值的欄位下方開始插入新一列的資料,
非常靠北
後來再github找到解
(這裡尾巴解)
https://github.com/burnash/gspread/issues/537
也就是你一定要”指定範圍”
$rangeNOW=’代墊費!:A60′;
//要指定代墊費這個工作表從A60格開始 append
‘工作表名稱!欄位點’
那很靠北的,也就是你要知道目前最後一列用到哪格了,
很抱歉sheet api沒有提供這個給php,不像mysql那樣方便
所以我自己用了很愚蠢的方式,先取得這工作表資料,再算出最後一列
//這邊算取得最後一ROW是第幾ROW
$range=’代墊費’;
$response = $service->spreadsheets_values->get($spreadsheetId, $range);
$value_all = $response->getValues();//所有資料
$lastRow_number=count($value_all); //取得最後一行,例如第111行
//$lastRow_number 這個就是目前最後一ROW囉
再回到上述程式
$rangeNOW=’代墊費!A’.$lastRow_number; //這樣就是 代墊費!A60 囉
$service->spreadsheets_values->append($spreadsheetId, $rangeNOW, $body, $params);
google sheet api wiht php 好多坑