การเขียนพื้นฐาน

Google ชีต API ช่วยให้คุณเขียนค่าและสูตรลงในเซลล์ ช่วง ชุดของช่วง และทั้งชีตได้ ตัวอย่างในหน้านี้แสดงวิธีดำเนินการเขียนทั่วไปบางอย่างด้วยทรัพยากร spreadsheets.values ของชีต API

โปรดทราบว่าคุณยังเขียนค่าเซลล์โดยใช้เมธอด spreadsheet.batchUpdate ได้อีกด้วย ซึ่งจะมีประโยชน์ในกรณีที่คุณต้องการอัปเดตการจัดรูปแบบเซลล์หรือพร็อพเพอร์ตี้อื่นๆ พร้อมกัน ซึ่งแหล่งข้อมูล spreadsheets.values จะไม่ส่งผลต่อค่าเหล่านั้น เช่น หากต้องการคัดลอกช่วงของเซลล์จากชีตหนึ่งไปยังอีกชีตหนึ่งขณะเขียนทับทั้งสูตรของเซลล์และการจัดรูปแบบของเซลล์ ให้ใช้เมธอด UpdateCellsRequest กับ spreadsheet.batchUpdate

อย่างไรก็ตาม สำหรับการเขียนค่าแบบง่าย การใช้วิธี spreadsheets.values.update หรือวิธี spreadsheets.values.batchUpdate จะง่ายกว่า

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

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

เขียนช่วงเดียว

เริ่มต้นด้วยสเปรดชีตใหม่เปล่า ตัวอย่างโค้ดต่อไปนี้ spreadsheets.values.update แสดงวิธีเขียนค่าลงในช่วง ต้องระบุพารามิเตอร์การค้นหา ValueInputOption และกำหนดว่าจะแยกวิเคราะห์ค่าที่เขียนหรือไม่ (เช่น แปลงสตริงเป็นวันที่หรือไม่)

เนื้อหาคําขอคือออบเจ็กต์ ValueRange ที่อธิบายค่าช่วงที่จะเขียน ช่อง majorDimension บ่งชี้ว่าอาร์เรย์คือรายการค่าที่จัดระเบียบตามแถว ระบบจะเขียนทับค่าที่มีอยู่ในช่วงที่กําหนด

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

PUT https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values/Sheet1!A1:D5?valueInputOption=VALUE_INPUT_OPTION
{
  "range": "Sheet1!A1:D5",
  "majorDimension": "ROWS",
  "values": [
    ["Item", "Cost", "Stocked", "Ship Date"],
    ["Wheel", "$20.50", "4", "3/1/2016"],
    ["Door", "$15", "2", "3/15/2016"],
    ["Engine", "$100", "1", "3/20/2016"],
    ["Totals", "=SUM(B2:B4)", "=SUM(C2:C4)", "=MAX(D2:D4)"]
  ],
}

การตอบกลับประกอบด้วยออบเจ็กต์ UpdateValuesResponse ดังตัวอย่างต่อไปนี้

{
  "spreadsheetId": SPREADSHEET_ID,
  "updatedRange": "Sheet1!A1:D5",
  "updatedRows": 5,
  "updatedColumns": 4,
  "updatedCells": 20,
}

ชีตที่ได้จะมีลักษณะดังต่อไปนี้

A C D
1 รายการ ค่าใช้จ่าย มีสินค้าพร้อมจำหน่าย วันที่จัดส่ง
2 ตั๋วขึ้นชิงช้าสวรรค์ $20.50 4 1/3/2016
3 ประตู $15 2 15/3/2016
4 เครื่องยนต์ $100 1 20/3/2016
5 ผลรวม $135.5 7 20/3/2016

เขียนข้อมูลบางส่วนไปยังช่วง

เมื่อเขียนค่าลงในช่วง คุณอาจหลีกเลี่ยงการเปลี่ยนแปลงเซลล์ที่มีอยู่บางเซลล์ได้โดยการตั้งค่าองค์ประกอบอาร์เรย์ที่เกี่ยวข้องเป็น null นอกจากนี้ คุณยังล้างเซลล์ได้โดยเขียนสตริงว่าง ("") ลงในเซลล์

เริ่มต้นด้วยชีตที่มีข้อมูลเดียวกันซึ่งสร้างโดยตัวอย่างด้านบน ตัวอย่างโค้ด spreadsheets.values.update ต่อไปนี้แสดงวิธีเขียนค่าไปยังช่วง B1:D4 โดยเลือกที่จะไม่เปลี่ยนแปลงเซลล์บางเซลล์และล้างเซลล์อื่นๆ ต้องระบุพารามิเตอร์การค้นหา ValueInputOption และกำหนดว่าจะแยกวิเคราะห์ค่าที่เขียนหรือไม่ (เช่น แปลงสตริงเป็นวันที่หรือไม่)

เนื้อหาคําขอคือออบเจ็กต์ ValueRange ที่อธิบายค่าช่วงที่จะเขียน ช่อง majorDimension บ่งชี้ว่าอาร์เรย์คือรายการค่าที่จัดระเบียบตามคอลัมน์

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

PUT https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values/Sheet1!B1?valueInputOption=VALUE_INPUT_OPTION
{
  "range": "Sheet1!B1",
  "majorDimension": "COLUMNS",
  "values": [
    [null,"$1","$2", ""],
    [],
    [null,"4/1/2016", "4/15/2016", ""]
  ]
}

ช่อง values แสดงการเปลี่ยนแปลงที่ทำกับแต่ละคอลัมน์ในช่วง อาร์เรย์แรกระบุว่า B1 จะไม่เปลี่ยนแปลง (เนื่องจากองค์ประกอบอาร์เรย์ null) ส่วน B4 จะต้องล้าง (สตริงว่าง) ค่าของ B2 และ B3 ได้รับการอัปเดตแล้ว อาร์เรย์ที่ 3 ดําเนินการเดียวกันกับคอลัมน์ D ส่วนอาร์เรย์ที่ 2 ซึ่งว่างเปล่าระบุว่าให้ปล่อยคอลัมน์ C ไว้ตามเดิม

การตอบกลับประกอบด้วยออบเจ็กต์ UpdateValuesResponse ดังตัวอย่างต่อไปนี้

{
  "spreadsheetId": SPREADSHEET_ID,
  "updatedRange": "Sheet1!B1:D5",
  "updatedRows": 3,
  "updatedColumns": 2,
  "updatedCells": 6,
}

ชีตที่ได้จะมีลักษณะดังต่อไปนี้

A C D
1 รายการ ค่าใช้จ่าย มีสินค้าพร้อมจำหน่าย วันที่จัดส่ง
2 ตั๋วขึ้นชิงช้าสวรรค์ $1.00 4 1/4/2016
3 ประตู 80 บาท 2 15/4/2016
4 เครื่องยนต์ 1
5 ผลรวม $3.00 7 15/4/2016

โปรดทราบว่าแถว "ผลรวม" แม้จะไม่ได้เปลี่ยนแปลงโดยตรงจากคําขอนี้ แต่ก็มีการเปลี่ยนแปลงเนื่องจากเซลล์มีสูตรที่ขึ้นอยู่กับเซลล์ที่เปลี่ยนแปลง

เขียนไปยังหลายช่วง

เริ่มต้นด้วยชีตว่าง ตัวอย่างโค้ดต่อไปนี้ spreadsheets.values.batchUpdate จะแสดงวิธีเขียนค่าไปยังช่วง Sheet1!A1:A4 และ Sheet1!B1:D2 ระบบจะเขียนทับค่าที่มีอยู่ในช่วงที่กําหนด เนื้อความของคำขอประกอบด้วยออบเจ็กต์ ValueInputOption ที่แสดงวิธีตีความข้อมูลอินพุตและอาร์เรย์ออบเจ็กต์ ValueRange ที่สอดคล้องกับแต่ละช่วงที่เขียน ช่อง majorDimension จะกำหนดว่าระบบจะตีความอาร์เรย์ที่รวมไว้เป็นอาร์เรย์ของคอลัมน์หรือแถว

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

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values:batchUpdate
{
  "valueInputOption": "VALUE_INPUT_OPTION",
  "data": [
    {
      "range": "Sheet1!A1:A4",
      "majorDimension": "COLUMNS",
      "values": [
        ["Item", "Wheel", "Door", "Engine"]
      ]
    },
    {
      "range": "Sheet1!B1:D2",
      "majorDimension": "ROWS",
      "values": [
        ["Cost", "Stocked", "Ship Date"],
        ["$20.50", "4", "3/1/2016"]
      ]
    }
  ]
}

การตอบกลับประกอบด้วยออบเจ็กต์ที่แสดงสถิติเซลล์ที่อัปเดตแล้ว และอาร์เรย์ออบเจ็กต์ UpdateValuesResponse 1 รายการสําหรับแต่ละช่วงที่อัปเดต เช่น

{
  "spreadsheetId": SPREADSHEET_ID,
  "totalUpdatedRows": 4,
  "totalUpdatedColumns": 4,
  "totalUpdatedCells": 10,
  "totalUpdatedSheets": 1,
  "responses": [
    {
      "spreadsheetId": SPREADSHEET_ID,
      "updatedRange": "Sheet1!A1:A4",
      "updatedRows": 4,
      "updatedColumns": 1,
      "updatedCells": 4,
    },
    {
      "spreadsheetId": SPREADSHEET_ID,
      "updatedRange": "Sheet1!B1:D2",
      "updatedRows": 2,
      "updatedColumns": 3,
      "updatedCells": 6,
    }
  ],
}

ชีตที่ได้จะมีลักษณะดังต่อไปนี้

A C D
1 รายการ ค่าใช้จ่าย มีสินค้าพร้อมจำหน่าย วันที่จัดส่ง
2 ตั๋วขึ้นชิงช้าสวรรค์ $20.50 4 1/3/2016
3 ประตู
4 เครื่องยนต์
5

เขียนค่าโดยไม่ต้องแยกวิเคราะห์

ตัวอย่างโค้ดต่อไปนี้ซึ่งเริ่มต้นด้วยชีตว่างจะแสดงวิธีเขียนค่าไปยังช่วง Sheet1!A1:E1 โดยใช้พารามิเตอร์การค้นหา RAW ValueInputOption เพื่อป้องกันไม่ให้ระบบแยกวิเคราะห์สตริงที่เขียนเป็นสูตร บูลีน หรือตัวเลขspreadsheets.values.update ข้อความจะปรากฏเป็นสตริงและการจัดตำแหน่งข้อความจะจัดชิดขวางในชีต

เนื้อหาคำขอคือออบเจ็กต์ ValueRange ที่อธิบายค่าช่วงที่จะเขียน ช่อง majorDimension บ่งชี้ว่าอาร์เรย์คือรายการค่าที่จัดระเบียบตามแถว ระบบจะเขียนทับค่าที่มีอยู่ในช่วงที่กําหนด

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

PUT https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values/Sheet1!A1:E1?valueInputOption=RAW
{
  "range": "Sheet1!A1:E1",
  "majorDimension": "ROWS",
  "values": [
    ["Data", 123.45, true, "=MAX(D2:D4)", "10"]
  ],
}

การตอบกลับประกอบด้วยออบเจ็กต์ UpdateValuesResponse ดังตัวอย่างต่อไปนี้

{
  "spreadsheetId": SPREADSHEET_ID,
  "updatedRange": "Sheet1!A1:E1",
  "updatedRows": 1,
  "updatedColumns": 5,
  "updatedCells": 5,
}

ชีตที่ได้จะมีลักษณะดังต่อไปนี้

A C D E
1 ข้อมูล 123.45 จริง =MAX(D2:D4) 10
2

โปรดทราบว่า "TRUE" อยู่กึ่งกลางและเป็นค่าบูลีน ส่วน "123.45" อยู่ชิดขวาเนื่องจากเป็นตัวเลข และ "10" อยู่ชิดซ้ายเนื่องจากเป็นสตริง ระบบจะไม่แยกวิเคราะห์สูตรและสูตรจะปรากฏเป็นสตริง

ต่อท้ายค่า

เริ่มต้นด้วยชีตแบบตารางด้านล่าง

A C D
1 รายการ ค่าใช้จ่าย มีสินค้าพร้อมจำหน่าย วันที่จัดส่ง
2 ตั๋วขึ้นชิงช้าสวรรค์ $20.50 4 1/3/2016
3

ตัวอย่างโค้ดต่อไปนี้ spreadsheets.values.append แสดงวิธีเพิ่มค่าแถวใหม่ 2 แถวโดยเริ่มจากแถวที่ 3 ต้องระบุพารามิเตอร์การค้นหา ValueInputOption และกำหนดว่าจะแยกวิเคราะห์ค่าที่เขียนหรือไม่ (เช่น สตริงจะแปลงเป็นวันที่หรือไม่)

เนื้อหาคำขอคือออบเจ็กต์ ValueRange ที่อธิบายค่าช่วงที่จะเขียน ช่อง majorDimension บ่งชี้ว่าอาร์เรย์คือรายการค่าที่จัดระเบียบตามแถว

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

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values/Sheet1!A1:E1:append?valueInputOption=VALUE_INPUT_OPTION
{
  "range": "Sheet1!A1:E1",
  "majorDimension": "ROWS",
  "values": [
    ["Door", "$15", "2", "3/15/2016"],
    ["Engine", "$100", "1", "3/20/2016"],
  ],
}

การตอบกลับประกอบด้วยออบเจ็กต์ AppendValuesResponse ดังตัวอย่างต่อไปนี้

{
  "spreadsheetId": SPREADSHEET_ID,
  "tableRange": "Sheet1!A1:D2",
  "updates": {
    "spreadsheetId": SPREADSHEET_ID,
    "updatedRange": "Sheet1!A3:D4",
    "updatedRows": 2,
    "updatedColumns": 4,
    "updatedCells": 8,
  }
}

ชีตที่ได้จะมีลักษณะดังต่อไปนี้

A C D
1 รายการ ค่าใช้จ่าย มีสินค้าพร้อมจำหน่าย วันที่จัดส่ง
2 ตั๋วขึ้นชิงช้าสวรรค์ $20.50 4 1/3/2016
3 ประตู $15 2 15/3/2016
4 เครื่องยนต์ $100 1 20/3/2016
5