การดําเนินการของชีต

Google Sheets API ให้คุณสร้าง ล้าง คัดลอก และลบชีต รวมถึงควบคุมพร็อพเพอร์ตี้ของชีต ตัวอย่างในหน้านี้จะแสดงวิธีที่คุณจะใช้ชีต API ทำงานบางอย่างได้

ตัวอย่างเหล่านี้แสดงในรูปแบบคำขอ HTTP โดยแสดงเป็นภาษากลาง หากต้องการดูวิธีใช้การอัปเดตแบบกลุ่มในภาษาต่างๆ โดยใช้ไลบรารีของไคลเอ็นต์ Google API โปรดดูอัปเดตสเปรดชีต

ในตัวอย่างต่อไปนี้ ตัวยึดตำแหน่ง SPREADSHEET_ID และ SHEET_ID ระบุตำแหน่งที่คุณจะระบุรหัสเหล่านั้น คุณดูรหัสของสเปรดชีตได้ใน URL ของสเปรดชีต คุณดูรหัสชีตได้โดยใช้เมธอด spreadsheets.get โดยจะระบุช่วงโดยใช้รูปแบบ A1 ช่วงตัวอย่างคือ Sheet1!A1:D5

เพิ่มชีต

ตัวอย่างโค้ด spreadsheets.batchUpdate ต่อไปนี้จะแสดงวิธีใช้ AddSheetRequest เพื่อเพิ่มชีตลงในสเปรดชีต และยังตั้งชื่อ ขนาดตารางกริด และสีแท็บด้วย

คำตอบจะประกอบด้วย AddSheetResponse ซึ่งมีออบเจ็กต์ที่มีพร็อพเพอร์ตี้ของชีตที่สร้างขึ้น (เช่น SHEET_ID)

โปรโตคอลคำขอแสดงอยู่ด้านล่าง

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "addSheet": {
        "properties": {
          "title": "Deposits",
          "gridProperties": {
            "rowCount": 20,
            "columnCount": 12
          },
          "tabColor": {
            "red": 1.0,
            "green": 0.3,
            "blue": 0.4
          }
        }
      }
    }
  ]
}

ล้างชีตของค่าทั้งหมดโดยยังเก็บรูปแบบไว้

ตัวอย่างโค้ด spreadsheets.batchUpdate ต่อไปนี้จะแสดงวิธีใช้ UpdateCellsRequest เพื่อนำค่าทั้งหมดออกจากชีตโดยที่ไม่เปลี่ยนแปลงการจัดรูปแบบ

การระบุช่อง userEnteredValue ที่ไม่มีค่าที่สอดคล้องกันจะได้รับการตีความว่าเป็นวิธีการล้างค่าในช่วง คุณสามารถใช้การตั้งค่านี้กับช่องอื่นๆ ได้เช่นกัน เช่น การเปลี่ยนค่า fields เป็น userEnteredFormat จะนำการจัดรูปแบบทั้งหมดที่ Sheets API รองรับออกจากชีต แต่ไม่เปลี่ยนแปลงค่าของเซลล์

โปรโตคอลคำขอแสดงอยู่ด้านล่าง

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "updateCells": {
        "range": {
          "sheetId": SHEET_ID
        },
        "fields": "userEnteredValue"
      }
    }
  ]
}

คัดลอกชีตจากสเปรดชีตหนึ่งไปยังอีกสเปรดชีตหนึ่ง

ตัวอย่างโค้ด spreadsheet.sheets.copyTo ต่อไปนี้แสดงวิธีคัดลอกชีตเดียวที่ SHEET_ID ระบุจากสเปรดชีตหนึ่งไปยังสเปรดชีตอื่น

ตัวแปร TARGET_SPREADSHEET_ID ในเนื้อหาคำขอระบุสเปรดชีตปลายทาง สำเนานี้จะเก็บค่า การจัดรูปแบบ สูตร และพร็อพเพอร์ตี้อื่นๆ ทั้งหมดของต้นฉบับไว้ ชื่อของชีตที่คัดลอกจะตั้งค่าเป็น "สำเนาของ [ชื่อชีตต้นฉบับ]"

การตอบกลับประกอบด้วยออบเจ็กต์ SheetProperties ที่อธิบายพร็อพเพอร์ตี้ของชีตที่สร้างขึ้น

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/sheets/SHEET_ID:copyTo
{
  "destinationSpreadsheetId": "TARGET_SPREADSHEET_ID"
}

ลบชีต

ตัวอย่างโค้ด spreadsheets.batchUpdate ต่อไปนี้จะแสดงวิธีใช้ DeleteSheetRequest เพื่อลบชีตที่ระบุโดย SHEET_ID

โปรโตคอลคำขอแสดงอยู่ด้านล่าง

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "deleteSheet": {
        "sheetId": SHEET_ID
      }
    }
  ]
}

อ่านข้อมูลชีต

ตัวอย่างโค้ด spreadsheets.get ต่อไปนี้แสดงวิธีรับข้อมูลพร็อพเพอร์ตี้ชีตจากสเปรดชีตที่ระบุโดย SHEET_ID และ SPREADSHEET_ID วิธีนี้มักใช้เพื่อระบุข้อมูลเมตาของชีตภายในสเปรดชีตหนึ่งๆ ดังนั้นการดำเนินการเพิ่มเติมจึงสามารถกำหนดเป้าหมายชีตเหล่านั้นได้ พารามิเตอร์การค้นหา fields จะระบุเฉพาะข้อมูลพร็อพเพอร์ตี้ของชีตที่ควรแสดง (ตรงข้ามกับข้อมูลค่าเซลล์หรือข้อมูลที่เกี่ยวข้องกับสเปรดชีตทั้งหมด)

GET https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID?&fields=sheets.properties

โดยการตอบสนองจะประกอบด้วยทรัพยากร Spreadsheet ซึ่งมีออบเจ็กต์ Sheet ที่มีองค์ประกอบ SheetProperties หากตั้งค่าช่องคำตอบหนึ่งๆ เป็นค่าเริ่มต้น ช่องนั้นจะไม่รวมอยู่ในการตอบกลับ

{
  "sheets": [
    {
      "properties": {
        "sheetId": SHEET_ID,
        "title": "Sheet1",
        "index": 0,
        "sheetType": "GRID",
        "gridProperties": {
          "rowCount": 100,
          "columnCount": 20,
          "frozenRowCount": 1
        }
        "tabColor": {
          "blue": 1.0
        }
      },
      ...
  ],
}