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à 2Cuố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ệudoData
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
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
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
?>