الرسومات البيانية

تتيح لك Google Sheets API إنشاء الرسوم البيانية وتعديلها ضمن جداول البيانات عند الحاجة. توضّح الأمثلة الواردة في هذه الصفحة كيفية تنفيذ بعض العمليات المشترَكة للرسوم البيانية باستخدام واجهة برمجة التطبيقات Sheets API.

يتم تقديم هذه الأمثلة في شكل طلبات HTTP لتكون متعافِية من اللغة. للتعرّف على كيفية تنفيذ تعديل مجمّع بلغات مختلفة باستخدام مكتبات برامج Google API، اطّلِع على مقالة تعديل جداول بيانات Google.

في هذين المثالَين، تشير العنصران النائبان SPREADSHEET_ID وSHEET_ID إلى المكان الذي يجب فيه تقديم معرّفات التطبيقَين. يمكنك العثور على رقم تعريف جدول البيانات في عنوان URL لجدول البيانات. يمكنك الحصول على معرّف جدول البيانات باستخدام الأسلوب spreadsheets.get. يتم تحديد النطاقات باستخدام ترميز A1. أحد مثالي النطاق هو الورقة1!A1:D5.

بالإضافة إلى ذلك، يشير العنصر النائب CHART_ID إلى معرّف هَرسَب معيّن. يمكنك ضبط هذا المعرّف عند إنشاء رسم بياني باستخدام Sheets API، أو السماح لواجهة برمجة التطبيقات Sheets API بإنشاء معرّف نيابةً عنك. يمكنك الحصول على أرقام تعريف الرسوم البيانية الحالية باستخدام spreadsheets.get.

أخيرًا، يشير العنصر النائب SOURCE_SHEET_ID إلى جدول البيانات الذي يحتوي على البيانات المصدر. في هذه الأمثلة، هذا هو الجدول المدرَج ضمن data مصدر الرسم البياني.

بيانات مصدر الرسم البياني

في ما يلي أمثلة على جدول البيانات الذي يتضمّن مصدر البيانات التالي في الورقة الأولى ("الورقة1"). السلاسل في الصف الأول هي تصنيفات للأعمدة الفردية. للاطّلاع على أمثلة عن كيفية القراءة من أوراق بيانات أخرى في جدول البيانات، اطّلِع على ترميز A1.

A ب C D E
1 رقم الطراز المبيعات - كانون الثاني (يناير) المبيعات - شباط (فبراير) المبيعات - آذار (مارس) إجمالي المبيعات
2 D-01X 68 74 60 202
3 FR-0B1 97 76 88 261
4 P-034 27 49 32 108
5 P-105 46 44 67 157
6 W-11 75 68 87 230
7 W-24 74 52 62 188

إضافة رسم بياني عمودي

يوضِّح نموذج الرمز البرمجي التالي spreadsheets.batchUpdate كيفية استخدام الرمز AddChartRequest لإنشاء رسم بياني أعمدة من البيانات المصدر، مع وضعه في ورقة بيانات جديدة. ينفِّذ طلب ما يلي لضبط الرسم البياني:

  • لضبط نوع الرسم البياني على رسم بياني عمودي
  • تضيف وسيلة إيضاح إلى أسفل الرسم البياني.
  • لضبط عناوين الرسم البياني والمحاور
  • ضبط 3 سلاسل بيانات تمثّل المبيعات لثلاثة أشهر مختلفة مع استخدام التنسيق والألوان التلقائية

يظهر بروتوكول الطلب أدناه.

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "addChart": {
        "chart": {
          "spec": {
            "title": "Model Q1 Sales",
            "basicChart": {
              "chartType": "COLUMN",
              "legendPosition": "BOTTOM_LEGEND",
              "axis": [
                {
                  "position": "BOTTOM_AXIS",
                  "title": "Model Numbers"
                },
                {
                  "position": "LEFT_AXIS",
                  "title": "Sales"
                }
              ],
              "domains": [
                {
                  "domain": {
                    "sourceRange": {
                      "sources": [
                        {
                          "sheetId": SOURCE_SHEET_ID,
                          "startRowIndex": 0,
                          "endRowIndex": 7,
                          "startColumnIndex": 0,
                          "endColumnIndex": 1
                        }
                      ]
                    }
                  }
                }
              ],
              "series": [
                {
                  "series": {
                    "sourceRange": {
                      "sources": [
                        {
                          "sheetId": SOURCE_SHEET_ID,
                          "startRowIndex": 0,
                          "endRowIndex": 7,
                          "startColumnIndex": 1,
                          "endColumnIndex": 2
                        }
                      ]
                    }
                  },
                  "targetAxis": "LEFT_AXIS"
                },
                {
                  "series": {
                    "sourceRange": {
                      "sources": [
                        {
                          "sheetId": SOURCE_SHEET_ID,
                          "startRowIndex": 0,
                          "endRowIndex": 7,
                          "startColumnIndex": 2,
                          "endColumnIndex": 3
                        }
                      ]
                    }
                  },
                  "targetAxis": "LEFT_AXIS"
                },
                {
                  "series": {
                    "sourceRange": {
                      "sources": [
                        {
                          "sheetId": SOURCE_SHEET_ID,
                          "startRowIndex": 0,
                          "endRowIndex": 7,
                          "startColumnIndex": 3,
                          "endColumnIndex": 4
                        }
                      ]
                    }
                  },
                  "targetAxis": "LEFT_AXIS"
                }
              ],
              "headerCount": 1
            }
          },
          "position": {
            "newSheet": true
          }
        }
      }
    }
  ]
}

ينشئ الطلب رسمًا بيانيًا في ورقة بيانات جديدة على النحو التالي:

إضافة نتيجة وصفة طعام إلى الرسم البياني العمودي

إضافة رسم بياني دائري

يوضّح نموذج الرمز البرمجي التالي spreadsheets.batchUpdate كيفية استخدام الرمز AddChartRequest لإنشاء مخطّط دائري ثلاثي الأبعاد من البيانات المصدر. ينفِّذ الطلب ما يلي ل ضبط الرسم البياني:

  • تُستخدَم لضبط عنوان الرسم البياني.
  • تضيف وسيلة إيضاح إلى يسار الرسم البياني.
  • تعيين الرسم البياني كرسم بياني دائري ثلاثي الأبعاد تجدر الإشارة إلى أنّه لا يمكن أن تتضمّن الرسوم البيانية للقطاعات الدائرية الثلاثية الأبعاد "ثقبًا في وسطها" كما هو الحال في الرسوم البيانية للقطاعات الدائرية المسطّحة.
  • لضبط سلسلة بيانات الرسم البياني على أنّها إجمالي المبيعات لكل رقم طراز.
  • ترسِّخ هذا العنصر الرسم البياني في الخلية C3 من ورقة البيانات المحدَّدة بواسطة SHEET_ID، مع إزاحة 50 بكسل في كلا الاتجاهَين X وY.

يظهر بروتوكول الطلب أدناه.

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "addChart": {
        "chart": {
          "spec": {
            "title": "Model Q1 Total Sales",
            "pieChart": {
              "legendPosition": "RIGHT_LEGEND",
              "threeDimensional": true,
              "domain": {
                "sourceRange": {
                  "sources": [
                    {
                      "sheetId": SOURCE_SHEET_ID,
                      "startRowIndex": 0,
                      "endRowIndex": 7,
                      "startColumnIndex": 0,
                      "endColumnIndex": 1
                    }
                  ]
                }
              },
              "series": {
                "sourceRange": {
                  "sources": [
                    {
                      "sheetId": SOURCE_SHEET_ID,
                      "startRowIndex": 0,
                      "endRowIndex": 7,
                      "startColumnIndex": 4,
                      "endColumnIndex": 5
                    }
                  ]
                }
              },
            }
          },
          "position": {
            "overlayPosition": {
              "anchorCell": {
                "sheetId": SHEET_ID,
                "rowIndex": 2,
                "columnIndex": 2
              },
              "offsetXPixels": 50,
              "offsetYPixels": 50
            }
          }
        }
      }
    }
  ]
}

ينشئ الطلب رسمًا بيانيًا على النحو التالي:

إضافة نتيجة وصفة طعام في الرسم البياني الدائري

بدلاً من ذلك، يمكنك أيضًا تعديل قيمة legendPosition من RIGHT_LEGEND إلى LABELED_LEGEND ضمن الطلب حتى يتم ربط قيم العنوان بقطاعات الرسم البياني الدائري.

'legendPosition': 'LABELED_LEGEND',

ينشئ الطلب المعدَّل رسمًا بيانيًا على النحو التالي:

إضافة نتيجة وصفة طعام في الرسم البياني الدائري

إضافة رسم بياني خطي باستخدام نطاقات متعددة غير متجاورة

يوضّح نموذج الرمز البرمجي التالي spreadsheets.batchUpdate كيفية استخدام الرمز AddChartRequest لإنشاء مخطّط خطي من البيانات المصدر، مع وضعه في ورقة البيانات المصدر. يمكن استخدام اختيار نطاقات غير متجاورة لاستبعاد الصفوف من ChartSourceRange.

ينفّذ الطلب ما يلي لضبط الرسم البياني:

  • لضبط نوع الرسم البياني على رسم بياني خطي
  • لضبط عنوان المحور الأفقي "س"
  • لضبط سلسلة بيانات تمثّل المبيعات ويضبط A1:A3 وA6:A7 على domain، وB1:B3 وB6:B7 على series، مع استخدام التنسيق والألوان التلقائية. يتم تحديد النطاقات باستخدام ترميز A1 في عنوان URL للطلب.
  • ترسِّخ الرسم البياني في الخلية H8 من ورقة البيانات المحدّدة بواسطة SHEET_ID.

يظهر بروتوكول الطلب أدناه.

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "addChart": {
        "chart": {
          "spec": {
            "basicChart": {
              "chartType": "LINE",
              "domains": [
                {
                  "domain": {
                    "sourceRange": {
                      "sources": [
                        {
                          "startRowIndex": 0,
                          "endRowIndex": 3,
                          "startColumnIndex": 0,
                          "endColumnIndex": 1,
                          "sheetId": SOURCE_SHEET_ID
                        },
                        {
                          "startRowIndex": 5,
                          "endRowIndex": 7,
                          "startColumnIndex": 0,
                          "endColumnIndex": 1,
                          "sheetId": SOURCE_SHEET_ID
                        }
                      ]
                    }
                  }
                }
              ],
              "series": [
                {
                  "series": {
                    "sourceRange": {
                      "sources": [
                        {
                          "startRowIndex": 0,
                          "endRowIndex": 3,
                          "startColumnIndex": 1,
                          "endColumnIndex": 2,
                          "sheetId": SOURCE_SHEET_ID
                        },
                        {
                          "startRowIndex": 5,
                          "endRowIndex": 7,
                          "startColumnIndex": 1,
                          "endColumnIndex": 2,
                          "sheetId": SOURCE_SHEET_ID
                        }
                      ]
                    }
                  }
                }
              ]
            }
          },
          "position": {
            "overlayPosition": {
              "anchorCell": {
                "sheetId": SOURCE_SHEET_ID,
                "rowIndex": 8,
                "columnIndex": 8
              }
            }
          }
        }
      }
    }
  ]
}

ينشئ الطلب رسمًا بيانيًا في ورقة بيانات جديدة على النحو التالي:

إضافة وصفة الرسم البياني الخطي للنطاق غير المجاور
النتيجة

حذف رسم بياني

يوضّح نموذج الرمز البرمجي التالي spreadsheets.batchUpdate كيفية استخدام العنصر DeleteEmbeddedObjectRequest لحذف رسم بياني محدّد بالعنصر CHART_ID.

يظهر بروتوكول الطلب أدناه.

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "deleteEmbeddedObject": {
        "objectId": CHART_ID
      }
    }
  ]
}

تعديل سمات الرسم البياني

يوضّح نموذج الرمز البرمجي التالي spreadsheets.batchUpdate كيفية استخدام العنصر UpdateChartSpecRequest لتعديل الرسم البياني الذي تم إنشاؤه في وصفة إضافة رسم بياني للأعمدة، وتعديل بياناته ونوعه ومظهره. لا يمكن تغيير المجموعات الفرعية لخصائص الرسم البياني بشكلٍ فردي. لإجراء تعديلات، عليك ملء الحقل spec بالكامل باستخدام UpdateChartSpecRequest. في الأساس، يتطلّب تعديل مواصفات الرسم البياني استبدالها بمواصفات جديدة.

يعدّل الطلب التالي الرسم البياني الأصلي (المحدّد باستخدام CHART_ID):

  • لضبط نوع الرسم البياني على BAR.
  • ينقل هذا الخيار وسيلة الإيضاح إلى يسار الرسم البياني.
  • تبديل المحاور بحيث تكون "المبيعات" على المحور السفلي و "أرقام الطُرز" على المحور الأيمن
  • لضبط تنسيق عنوان المحور على خط بحجم 24 نقطة ومكثّف ومائل.
  • تزيل بيانات "W-24" من الرسم البياني (الصف 7 في مصدر الرسم البياني البيانات).

يظهر بروتوكول الطلب أدناه.

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "updateChartSpec": {
        "chartId": CHART_ID,
        "spec": {
          "title": "Model Q1 Sales",
          "basicChart": {
            "chartType": "BAR",
            "legendPosition": "RIGHT_LEGEND",
            "axis": [
              {
                "format": {
                  "bold": true,
                  "italic": true,
                  "fontSize": 24
                },
                "position": "BOTTOM_AXIS",
                "title": "Sales"
              },
              {
                "format": {
                  "bold": true,
                  "italic": true,
                  "fontSize": 24
                },
                "position": "LEFT_AXIS",
                "title": "Model Numbers"
              }
            ],
            "domains": [
              {
                "domain": {
                  "sourceRange": {
                    "sources": [
                      {
                        "sheetId": SOURCE_SHEET_ID,
                        "startRowIndex": 0,
                        "endRowIndex": 6,
                        "startColumnIndex": 0,
                        "endColumnIndex": 1
                      }
                    ]
                  }
                }
              }
            ],
            "series": [
              {
                "series": {
                  "sourceRange": {
                    "sources": [
                      {
                        "sheetId": SOURCE_SHEET_ID,
                        "startRowIndex": 0,
                        "endRowIndex": 6,
                        "startColumnIndex": 1,
                        "endColumnIndex": 2
                      }
                    ]
                  }
                },
                "targetAxis": "BOTTOM_AXIS"
              },
              {
                "series": {
                  "sourceRange": {
                    "sources": [
                      {
                        "sheetId": SOURCE_SHEET_ID,
                        "startRowIndex": 0,
                        "endRowIndex": 6,
                        "startColumnIndex": 2,
                        "endColumnIndex": 3
                      }
                    ]
                  }
                },
                "targetAxis": "BOTTOM_AXIS"
              },
              {
                "series": {
                  "sourceRange": {
                    "sources": [
                      {
                        "sheetId": SOURCE_SHEET_ID,
                        "startRowIndex": 0,
                        "endRowIndex": 6,
                        "startColumnIndex": 3,
                        "endColumnIndex": 4
                      }
                    ]
                  }
                },
                "targetAxis": "BOTTOM_AXIS"
              }
            ],
            "headerCount": 1
          }
        }
      }
    }
  ]
}

بعد الطلب، يظهر الرسم البياني على النحو التالي:

تعديل نتيجة الوصفة في الرسم البياني

نقل رسم بياني أو تغيير حجمه

يوضّح نموذج الرمز البرمجي التالي spreadsheets.batchUpdate كيفية استخدام الرمز UpdateEmbeddedObjectPositionRequest لنقل مخطّط بياني وتغيير حجمه. بعد الطلب، يكون الرسم البياني الذي حدّده CHART_ID:

  • تم تثبيتها في الخلية A5 من ورقة البيانات الأصلية.
  • إزاحة في اتجاه X بمقدار 100 بكسل
  • تم تغيير حجمها إلى 1200 × 742 بكسل (الحجم التلقائي للرسم البياني هو 600 × 371 بكسل).

لا يغيّر الطلب سوى تلك الخصائص المحدّدة باستخدام المَعلمة fields. تحتفظ السمات الأخرى (مثل offsetYPixels) بقيمها الأصلية.

يظهر بروتوكول الطلب أدناه.

POST https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID:batchUpdate
{
  "requests": [
    {
      "updateEmbeddedObjectPosition": {
        "objectId": CHART_ID,
        "newPosition": {
          "overlayPosition": {
            "anchorCell": {
              "rowIndex": 4,
              "columnIndex": 0
            },
            "offsetXPixels": 100,
            "widthPixels": 1200,
            "heightPixels": 742
          }
        },
        "fields": "anchorCell(rowIndex,columnIndex),offsetXPixels,widthPixels,heightPixels"
      }
    }
  ]
}

قراءة بيانات الرسم البياني

يوضّح رمز النموذج التالي spreadsheets.get كيفية الحصول على بيانات الرسم البياني من جدول بيانات. تُحدِّد مَعلمة طلب البحث fields أنّه يجب عرض بيانات الرسم البياني فقط.

الاستجابة لاستدعاء هذه الطريقة هي عنصر spreadsheet الذي يحتوي على صفيف من عناصر sheet. يتم تمثيل أيّ رسوم بيانية متوفّرة في ورقة بيانات في كائن sheet. إذا تم ضبط حقل الردّ على القيمة التلقائية، سيتم حذفه من الردّ.

في هذا المثال، لا تحتوي الورقة الأولى (SOURCE_SHEET_ID) على أيّ رسوم بيانية، لذا يتم عرض زوج فارغ من الأقواس المتعرجة. تحتوي الورقة الثانية على الرسم البياني الذي تم إنشاؤه باستخدام إضافة رسم بياني عمودي، ولا تحتوي على أي شيء آخر.

يظهر بروتوكول الطلب أدناه.

GET https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID?fields=sheets(charts)
{
  "sheets": [
    {},
    {
      "charts": [
        {
          "chartId": CHART_ID,
          "position": {
            "sheetId": SHEET_ID
          },
          "spec": {
            "basicChart": {
              "axis": [
                {
                  "format": {
                    "bold": false,
                    "italic": false
                  },
                  "position": "BOTTOM_AXIS",
                  "title": "Model Numbers"
                },
                {
                  "format": {
                    "bold": false,
                    "italic": false
                  },
                  "position": "LEFT_AXIS",
                  "title": "Sales"
                }
              ],
              "chartType": "COLUMN",
              "domains": [
                {
                  "domain": {
                    "sourceRange": {
                      "sources": [
                        {
                          "endColumnIndex": 1
                          "endRowIndex": 7,
                          "sheetId": SOURCE_SHEET_ID,
                          "startColumnIndex": 0,
                          "startRowIndex": 0,
                        }
                      ]
                    }
                  }
                }
              ],
              "legendPosition": "BOTTOM_LEGEND",
              "series": [
                {
                  "series": {
                    "sourceRange": {
                      "sources": [
                        {
                          "endColumnIndex": 2,
                          "endRowIndex": 7,
                          "sheetId": SOURCE_SHEET_ID,
                          "startColumnIndex": 1,
                          "startRowIndex": 0,
                        }
                      ]
                    }
                  },
                  "targetAxis": "LEFT_AXIS"
                },
                {
                  "series": {
                    "sourceRange": {
                      "sources": [
                        {
                          "endColumnIndex": 3,
                          "endRowIndex": 7,
                          "sheetId": SOURCE_SHEET_ID,
                          "startColumnIndex": 2,
                          "startRowIndex": 0,
                        }
                      ]
                    }
                  },
                  "targetAxis": "LEFT_AXIS"
                },
                {
                  "series": {
                    "sourceRange": {
                      "sources": [
                        {
                          "endColumnIndex": 4,
                          "endRowIndex": 7,
                          "sheetId": SOURCE_SHEET_ID,
                          "startColumnIndex": 3,
                          "startRowIndex": 0,
                        }
                      ]
                    }
                  },
                  "targetAxis": "LEFT_AXIS"
                }
              ]
            },
            "hiddenDimensionStrategy": "SKIP_HIDDEN_ROWS_AND_COLUMNS",
            "title": "Model Q1 Sales",
          },
        }
      ]
    }
  ]
}