Đọc google sheet trên php

Tiếp theo series quản lý web với google sheet, 2 bài trước mình đã hướng dẫn các bạn thu thập thông tin vào google sheet, giờ bài này mình sẽ hướng dẫn các bạn in dữ liệu từ google sheet ra như in từ database ra nhé

2 bài trước mình đều hướng dẫn các bạn xử lý không dùng ngôn ngữ backend nào, hoàn toàn hướng dẫn sử dụng script, nhờ đó mà không cần nhiều kiến thức ngôn ngữ backend vẫn có thể làm được. Bài này mình cũng có 1 cách chỉ sử dụng js, không dùng ngôn ngữ backend. Tuy nhiên nhược điểm của cách này là lộ hết code, và lộ cả link google sheet của bạn nữa [sohai]. Vậy nên mình khuyến khích mọi người sử dụng cách 2: sử dụng ngôn ngữ backend, xử lý đọc dữ liệu hết trước khi in ra web cho người dùng đọc, tại đây mình sử dụng ngôn ngữ đơn giản - PHP với những hàm đơn giản thôi, và không sử dụng đến google API vì nó khá phức tạp.

Chuẩn bị

Tất nhiên là cần phải chuẩn bị dữ liệu trên google sheet để có cái mà in ra rồi :v.

Để dễ dàng và đơn giản nhất, các bạn nên coi 1 file google sheet làm DB của 1 web, mỗi sheet lưu nội dung của 1 "bảng" trong DB đó. Tất nhiên có thể chia ra nhiều file google khác nhau cũng được, nhưng như vậy mất công chúng ta tìm kiếm và mở nhiều file thôi

Với mỗi sheet, mình quy định như sau: mỗi cột chính là 1 Field - trường dữ liệu, mỗi hàng là 1 bản ghi. Lấy ví dụ bảng News của mình như sau nhé:

Giờ khi có các "bảng" dữ liệu rồi, các bạn lưu ý các thông tin sau nhé:

  • URL sheet => lấy ra google sheet code. Bạn cần phải lấy mã của google sheet, hướng dẫn như sau: Link google sheet của bạn sẽ có dạng như thế này: //docs.google.com/spreadsheets/d/1DjUVVsMdYsajrMRmR-3YPaQ7akiRvK1njJIAPf5EOXI/edit#gid=1150305447 thì bạn sẽ trích xuất google sheet code như sau:

  • Page number: Để lấy thông tin đúng bảng, thì ngoài google sheet code ở trên, phải lưu ý lấy đúng số thứ tự sheet nhé. Số thứ tự sẽ đếm từ 1, VD như sheet News của mình thì page number sẽ là 2

  • Cuối cùng, các bạn lưu ý thứ tự các cột - Field đúng với thứ tự bạn mong muốn nhé

Sử dụng JS

Xử lý URL lấy dữ liệu

Để có thể truy cập dữ liệu trong google sheet bằng web của bạn, tất nhiên là phải public cho phép xem trước. Để public được, bạn vào File -> Publish to the web như dưới đây:

Sau đó chọn public Public to the Web các sheet bạn muốn [lưu ý trang nào muốn lấy dữ liệu phải được public rồi đã], hoặc cả google sheet đó luôn

.

, khi đó đường link public RSS URL sẽ trông như sau:

//spreadsheets.google.com/feeds/cells/YOURGOOGLESHEETCODE/SHEETPAGENUMBER/public/values

Tuy nhiên để thuận tiện cho việc đọc dữ liệu dễ dàng, thì dạng JSON sẽ giúp cho việc phân tách dữ liệu các hàng / các cột thuận tiện hơn, vậy nên URL để lấy dữ liệu cần có chút thay đổi để trở thành public JSON URL như sau:

//spreadsheets.google.com/feeds/cells/YOURGOOGLESHEETCODE/SHEETPAGENUMBER/public/values?alt=json-in-script

Bạn có thể test xem dữ liệu in ra JSON ra sao rồi bằng cách vào đường dẫn xem thử và thêm Json formater cho dễ nhìn nhé Do tính chất bất đồng bộ của JS, vậy nên việc đọc dữ liệu từ google sheet kia có thể mất chút thời gian. Để đảm bảo cho sau khi đọc được hết dữ liệu từ file google sheet của bạn rồi bạn mới tiến hành xử lý dữ liệu, thì hãy thêm 1 function callback sẽ chạy hàm xử lý dữ liệu doData vào URL nữa nhé:

//spreadsheets.google.com/feeds/cells/YOURGOOGLESHEETCODE/SHEETPAGENUMBER/public/values?alt=json-in-script&callback=doData

Vậy là đã có link sử dụng để đọc dữ liệu từ google sheet trả về Json để xử lý rồi, việc tiếp theo sẽ là xử lý đám dữ liệu này hiển thị ra cho đúng cách và đúng chỗ nhé.

Chuẩn bị chỗ chèn dữ liệu [Xử lý html tại vị trí sẽ chèn dữ liệu]

Trong file HTML của mình, mình sẽ đặt 1

và dữ liệu sau khi xử lý sẽ insert vào trong div này nhé:

DOCTYPE html>


    
    
    


    Lấy dữ liệu từ google sheet
    
        
    


Xử lý dữ liệu để in ra

Giờ tất nhiên là công việc phức tạp nhất: xử lý dữ liệu in ra sao cho đúng ý muốn của bạn. Mình sẽ khởi tạo 1 biến để lưu dữ liệu từ google sheet, sau đó sử dụng hàm doData để 'nhét' dữ liệu mình cần vào nhé:

var spData = null;
function doData[json] {
    spData = json.feed.entry;
    //nếu cần kiểm tra thì thử console.log phát xem dữ liệu đang có dạng như nào nhé
    console.log[spData];
}

Vì sao lại là json.feed.entry? Để biết vì sao thì bạn thử truy cập URL lấy dữ liệu và xem thử hàm doData trả lại dữ liệu JSON như nào nhé: //spreadsheets.google.com/feeds/cells/YOURGOOGLESHEETCODE/SHEETPAGENUMBER/public/values?alt=json-in-script&callback=doData

Như các bạn thấy và click thử vào các đối tượng dữ liệu kia, thì nội dung của "bảng" mà chúng ta cần nằm trong doData->feed->entry. Ở kia mỗi item trong entry chính là thông tin của 1 ô dữ liệu.

Việc tiếp theo là xử lý dữ liệu để in ra. Tất nhiên là với dữ liệu JSON kia đã đọc được rồi thì các bạn cũng có thể tự nghĩ cách xử lý cho phù hợp, ở đây mình hướng dẫn đơn giản làm ví dụ vừa in dữ liệu vừa in HTML cho đẹp nhé:

Sử dụng 1 hàm readData[] để xử lý. Hàm này sẽ được gọi đến sau khi toàn bộ trang web và dữ liệu đã được xử lý hết, như vậy bảo đảm đã có các thành phần khác, đọc dữ liệu cũng đã xong, đã có dữ liệu và chỉ việc 'mổ xẻ' nó thôi:

function readData[] {
    var data = spData;
    var strData = ''; //biến này chứa đoạn mã html sẽ in ra
    //Xử lý code ở đây [xem nội dung phần dưới]
    $['#data'].after[strData]; //in đám html lưu trong strData vào trong div có id là data
}
$[document].ready[function[] {
    readData[];
}];

Giờ bắt đầu phân tích này: Như đã nói ở trên, mỗi 1 item trong json.feed.entry chỉ là 1 ô dữ liệu thôi, vậy làm thế nào để lọc ra mỗi hàng, ứng với mỗi bản ghi? Sau đó lặp lại để xử lý html y hệt với bản ghi tiếp theo? Nếu mở các item ra, sẽ thấy nội dung của ô được lưu trong gs$cell:

Trong này có 3 item cần chú ý:

  • row: hàng số 2 - bản ghi thứ 2 trong "Bảng"
  • col: cột số 2 - Trường ở vị trí thứ 2 theo thứ tự trong "Bảng" [như đã lưu ý từ đầu, chú ý đúng thứ tự nhé]
  • $t: nội dung bên trong ô

Vậy là giờ cần phân tích từng item trong entry kia, xét hàng và cột của nó để biết nội dung nó đang chứa là cái gì. Thực tế bạn chủ yếu chỉ cần chú ý vào số cột, vì dữ liệu được đọc theo thứ tự từ trái sang đến ô dữ liệu cuối, sau đó lại lộn xuống hàng thứ 2 và tiếp tục như vậy. Vậy thì cứ xử lý tới cột cuối cùng thì coi như đã xong 1 bản ghi, xử lý tiếp theo sẽ là dữ liệu của bản ghi tiếp theo rồi

. Tất nhiên điều này có nghĩa là bạn phải nắm được cột 1 chứa gì, cột 2 chứa gì, cột cuối cùng là cột số bao nhiêu, như vậy xử lý mới chính xác được. Hơi "hard code" tí nhưng mà các bạn có thể làm nó "logic" hơn, nhưng sẽ dài hơn và ở đây mình hướng dẫn đơn giản thôi nhé.

Giờ phân tích từng ô dữ liệu [ứng với từng gs$cell], như trong dữ liệu mẫu của mình thì hàng đầu tiên là tên trường - mình sẽ để là , hoặc các bạn bỏ qua, tùy ý. Và tổng cộng mình có 4 trường dữ liệu tất cả. Như vật mình sẽ tách ra xử lý hàng đầu tiên riêng, và xử lý các hàng tiếp theo sẽ giống nhau [cùng là bản ghi dữ liệu], đồng thời tổng cộng xử lý là 4 cột trường dữ liệu để in ra.

for [var r = 0; r = 0 && r $t
        } else if [cell["col"] == "2"] { //cột thứ 2 mình lưu title
            strData += '' + cell["$t"] + '';
        } else if [cell["col"] == "3"] {  //cột thứ3 mình lưu link ảnh, với th thì vẫn in bình thường, nhưng xuống tới dưới sẽ in thành hình ảnh nhé
            strData += '' + cell["$t"] + '';
        } else if [cell["col"] == "4"] { //cột cuối lưu mô tả ngắn cho bài
            strData += '' + cell["$t"] + '';
            strData += '';
        }
    } else { //xử lý các bản ghi dữ liệu bình thường
        if [cell["col"] == "1"] {
            strData += '';
            strData += '' + cell["$t"] + '';
        } else if [cell["col"] == "2"] {
            strData += '' + cell["$t"] + '';
        } else if [cell["col"] == "3"] {
            strData += '';
        } else if [cell["col"] == "4"] {
            strData += '' + cell["$t"] + '';
            strData += '';
        }
    }
}

Chạy thử sẽ thấy kết quả như dưới đây nhé:

Dưới đây là toàn bộ code demo cho các bạn thử, nhớ thay link google sheet của các bạn vào nhé:

DOCTYPE html>


    
    
    
    
    
    
        var spData = null;

        function doData[json] {
            spData = json.feed.entry;
        }
        function readData[] {
            var data = spData;
            var strData = '';
            // consolr.log
            for [var r = 0; r = 0 && r 



    
        
    



Sử dụng PHP

Như đã nói từ đầu, sử dụng js như đoạn code trên mặc dù đơn giản, "ăn liền" nhưng chỉ cần Inspect code lên cái là lộ luôn cái file google sheet của bạn rồi [capcuu]. Chính vì vậy mình khuyến khích các bạn sử dụng thêm 1 ngôn ngữ backend, mình sử dụng PHP, để xử lý hết dữ liệu rồi mới in ra màn hình. Cách làm thì cũng đơn giản

Lại là xử lý URL

Tương tự như trên, chúng ta cũng xử lý dữ liệu dạng json nhé, URL để sử dụng cũng na ná như trên kia thôi, khác tí tẹo

//spreadsheets.google.com/feeds/cells/YOURGOOGLESHEETCODE/SHEETPAGENUMBER/public/values?alt=json

Tất nhiên là vào thử link thấy dữ liệu cũng như trên, tức là thông tin cần lấy ở feed->entry->gs$cell

Về HTML

Lợi thế của PHP chính là tính linh động [hay cũng là sự "trông xấu" của PHP

], vì vậy bạn cứ chỗ nào muốn in dữ liệu thì viết mã PHP để in vào đó, xong xuôi lại đóng thẻ PHP viết tiếp HTML là được, không cần lằng nhằng vẽ cột, chèn vào vị trí như trên.

Lấy dữ liệu ra và "mổ xẻ thêm mắm muối"


Giờ đã có 1 tập dữ liệu của từng ô như bên trên rồi. Tiếp theo lại là phân tích các tập dữ liệu này, tùy thuộc vào ô đó thuộc cột bao nhiêu để lấy được dữ liệu tương ứng viết vào đúng chỗ.

$i = 1; //Hàng đầu tiên
foreach [$rows as $row] {
    if [$i == 1] { //nếu là hàng đầu tiên thì xử lý nó thành th, hoặc bỏ qua, như phía trên
        switch [$row->{'gs$cell'}->{'col'}] {
            case '1': //cột 1 là cột mở hàng tr
            ?>
            
                 
            
             
         
        
                  
            
                
            
                
             
        
                 

Chủ Đề