টেবিল নিয়ে কাজ করা

গুগল ডক্স এপিআই আপনাকে টেবিলের বিষয়বস্তু সম্পাদনা করার সুযোগ দেয়। আপনি নিম্নলিখিত কাজগুলো করতে পারবেন:

  • সারি, কলাম বা সম্পূর্ণ টেবিল যোগ করুন এবং মুছে ফেলুন।
  • টেবিলের সেলগুলোতে বিষয়বস্তু প্রবেশ করান।
  • টেবিলের সেলগুলো থেকে বিষয়বস্তু পড়ুন।
  • কলামের বৈশিষ্ট্য এবং সারিগুলোর স্টাইল পরিবর্তন করুন।

গুগল ডক্স-এ টেবিলকে ডকুমেন্টের মধ্যে এক ধরনের স্ট্রাকচারাল এলিমেন্ট (StructuralElement) হিসেবে উপস্থাপন করা হয়। প্রতিটি টেবিলে টেবিল রো- এর একটি তালিকা থাকে, যেখানে প্রতিটি রো-তে টেবিল সেল- এর একটি তালিকা থাকে। অন্যান্য সকল স্ট্রাকচারাল এলিমেন্টের মতোই, টেবিলেরও স্টার্ট এবং এন্ড ইনডেক্স থাকে, যা ডকুমেন্টে টেবিলটির অবস্থান নির্দেশ করে। ইনডেক্সিং সম্পর্কে আরও তথ্যের জন্য এর গঠন (structure) দেখুন। টেবিলের প্রোপার্টিগুলোর মধ্যে কলামের প্রস্থ (column width) এবং প্যাডিং (padding)-এর মতো অনেক স্টাইল এলিমেন্ট অন্তর্ভুক্ত থাকে।

নিম্নলিখিত JSON খণ্ডটিতে বেশিরভাগ বিবরণ বাদ দিয়ে একটি সাধারণ 2x2 টেবিল দেখানো হয়েছে:

"table": {
    "columns": 2,
    "rows": 2,
    "tableRows": [
        { "tableCells": [
                {
                    "content": [ { "paragraph": { ...  }, } ],
                },
                {
                    "content": [ { "paragraph": { ... }, } ],
                }
            ],
        },
        {
            "tableCells": [
                {
                    "content": [ { "paragraph": { ... }, } ],
                },
                {
                    "content": [ { "paragraph": { ... }, } ],
                }
            ],
        }
    ]
}

টেবিল ঢোকানো এবং মুছে ফেলা

কোনো ডকুমেন্টে নতুন টেবিল যোগ করতে InsertTableRequest ব্যবহার করুন। টেবিল সন্নিবেশ করার সময় আপনাকে অবশ্যই নিম্নলিখিত বিষয়গুলো উল্লেখ করতে হবে:

  • টেবিলের সারি এবং কলামের মাত্রা।
  • নতুন টেবিলটি সন্নিবেশ করার স্থান: এটি একটি সেগমেন্টের ভেতরের কোনো ইনডেক্স হতে পারে, অথবা সেগমেন্টের শেষও হতে পারে। উভয় ক্ষেত্রেই নির্দিষ্ট ট্যাবের আইডি অবশ্যই অন্তর্ভুক্ত থাকতে হবে।

টেবিল মুছে ফেলার কোনো সুস্পষ্ট পদ্ধতি নেই। একটি ডকুমেন্ট থেকে টেবিল মুছে ফেলার জন্য, এটিকে অন্য যেকোনো কন্টেন্টের মতোই ব্যবহার করুন: DeleteContentRangeRequest ব্যবহার করুন এবং এমন একটি রেঞ্জ উল্লেখ করুন যা পুরো টেবিলটিকে অন্তর্ভুক্ত করে।

নিম্নলিখিত উদাহরণটি একটি খালি ডকুমেন্টের শেষে একটি 3x3 টেবিল সন্নিবেশ করে:

জাভা

// Insert a table at the end of the body.
// (An empty or unspecified segmentId field indicates the document's body.)

List<Request> requests = new ArrayList<>();
requests.add(
    new Request()
        .setInsertTable(
            new InsertTableRequest()
                .setEndOfSegmentLocation(
                    new EndOfSegmentLocation().setTabId(<var>TAB_ID</var>))
                .setRows(3)
                .setColumns(3)));

BatchUpdateDocumentRequest body =
    new BatchUpdateDocumentRequest().setRequests(requests);
BatchUpdateDocumentResponse response =
    docsService.documents().batchUpdate(<var>DOCUMENT_ID</var>, body).execute();

পাইথন

# Insert a table at the end of the body.
# (An empty or unspecified segmentId field indicates the document's body.)

requests = [{
    'insertTable': {
        'rows': 3,
        'columns': 3,
        'endOfSegmentLocation': {
          'segmentId': '',
          'tabId': <var>TAB_ID</var>
        }
    },
}
]

result = service.documents().batchUpdate(documentId=<var>DOCUMENT_ID</var>, body={'requests': requests}).execute()

এই সংশ্লিষ্ট উদাহরণটি দেখায় কিভাবে পূর্বে সন্নিবেশিত টেবিলটি মুছে ফেলতে হয়:

জাভা

// Delete a table that was inserted at the start of the body of the first tab.
// (The table is the second element in the body:
//  documentTab.getBody().getContent().get(2).)

Document document = docsService.documents().get(<var>DOCUMENT_ID</var>).setIncludeTabsContent(true).execute();
String tabId = document.getTabs()[0].getTabProperties().getTabId();
DocumentTab documentTab = document.getTabs()[0].getDocumentTab();
StructuralElement table = documentTab.getBody().getContent().get(2);

List<Request> requests = new ArrayList<>();
requests.add(
    new Request()
        .setDeleteContentRange(
            new DeleteContentRangeRequest()
                .setRange(
                    new Range()
                        .setStartIndex(table.getStartIndex())
                        .setEndIndex(table.getEndIndex())
                        .setTabId(tabId))));

BatchUpdateDocumentRequest body =
    new BatchUpdateDocumentRequest().setRequests(requests);
BatchUpdateDocumentResponse response =
    docsService.documents().batchUpdate(<var>DOCUMENT_ID</var>, body).execute();

পাইথন

# Delete a table that was inserted at the start of the body of the first tab.
# (The table is the second element in the body: ['body']['content'][2].)

document = service.documents().get(documentId=DOCUMENT_ID, includeTabsContent=True).execute()
tab_id = document['tabs'][0]['tabProperties']['tabId']
document_tab = document['tabs'][0]['documentTab']
table = document_tab['body']['content'][2]

requests = [{
    'deleteContentRange': {
      'range': {
        'segmentId': '',
        'startIndex': table['startIndex'],
        'endIndex':   table['endIndex'],
        'tabId': tab_id
      }
    },
}
]

result = service.documents().batchUpdate(documentId=<var>DOCUMENT_ID</var>, body={'requests': requests}).execute()

যেহেতু আপনি শুরু এবং শেষের ইনডেক্স উল্লেখ করে একটি টেবিলকে সাধারণ কন্টেন্ট হিসেবে ডিলিট করেন, তাই আপনাকে এই ইনডেক্সগুলো কোনো এক জায়গা থেকে সংগ্রহ করতে হবে। উদাহরণটিতে ডকুমেন্ট কন্টেন্ট থেকে এই ইনডেক্সগুলো বের করার একটি উপায় দেখানো হয়েছে।

সারি যোগ করা এবং মুছে ফেলা

আপনার ডকুমেন্টে যদি আগে থেকেই একটি টেবিল থাকে, তাহলে Google Docs API আপনাকে টেবিলের সারি যোগ করতে এবং মুছে ফেলতে দেয়। একটি নির্দিষ্ট টেবিল সেলের উপরে বা নীচে সারি যোগ করতে InsertTableRowRequest ব্যবহার করুন এবং নির্দিষ্ট সেলের অবস্থান জুড়ে থাকা সারিটি মুছে ফেলতে DeleteTableRowRequest ব্যবহার করুন।

নিম্নলিখিত উদাহরণটি একটি টেবিলের প্রথম সেলে টেক্সট প্রবেশ করায় এবং একটি টেবিল সারি যোগ করে।

জাভা

List<Request> requests = new ArrayList<>();
requests.add(new Request().setInsertText(new InsertTextRequest()
        .setText("Hello")
        .setLocation(new Location().setIndex(5).setTabId(<var>TAB_ID</var>))));
requests.add(new Request().setInsertTableRow(new InsertTableRowRequest()
        .setTableCellLocation(new TableCellLocation()
                .setTableStartLocation(new Location()
                        .setIndex(2).setTabId(<var>TAB_ID</var>))
                .setRowIndex(1)
                .setColumnIndex(1))
        .setInsertBelow(true)));

BatchUpdateDocumentRequest body =
    new BatchUpdateDocumentRequest().setRequests(requests);
BatchUpdateDocumentResponse response = docsService.documents()
        .batchUpdate(<var>DOCUMENT_ID</var>, body).execute();

পাইথন

requests = [{
      'insertText': {
        'location': {
          'index': 5,
          'tabId': <var>TAB_ID</var>
        },
        'text': 'Hello'
    }
  },
  {
    'insertTableRow': {
        'tableCellLocation': {
            'tableStartLocation': {
                'index': 2,
                'tabId': <var>TAB_ID</var>
            },
            'rowIndex': 1,
            'columnIndex': 1
        },
        'insertBelow': 'true'
    }
  }
]

result = service.documents().batchUpdate(documentId=<var>DOCUMENT_ID</var>, body={'requests': requests}).execute()

কলাম যোগ এবং মুছে ফেলা

বিদ্যমান টেবিলে একটি কলাম যোগ করতে, InsertTableColumnRequest ব্যবহার করুন। আপনাকে নিম্নলিখিত বিষয়গুলো অবশ্যই উল্লেখ করতে হবে:

  • একটি সেল যার পাশে আপনি একটি নতুন কলাম যোগ করতে চান।
  • নতুন কলামটি কোন দিকে (বাম না ডান) যোগ করতে হবে।

নিম্নলিখিত উদাহরণে দেখানো হয়েছে, কীভাবে আপনি পূর্বে দেখানো 2x2 টেবিলে একটি কলাম যুক্ত করতে পারেন:

জাভা

List<Request> requests = new ArrayList<>();
requests.add(
    new Request()
        .setInsertTableColumn(
            new InsertTableColumnRequest()
                .setTableCellLocation(
                    new TableCellLocation()
                        .setTableStartLocation(
                            new Location().setIndex(2).setTabId(<var>TAB_ID</var>))
                        .setRowIndex(0)
                        .setColumnIndex(0))
                .setInsertRight(true)));

BatchUpdateDocumentRequest body =
    new BatchUpdateDocumentRequest().setRequests(requests);
BatchUpdateDocumentResponse response =
    docsService.documents().batchUpdate(<var>DOCUMENT_ID</var>, body).execute();

পাইথন

requests = [{
    'insertTableColumn': {
      'tableCellLocation': {
        'tableStartLocation': {
          'segmentId': '',
          'index': 2,
          'tabId': <var>TAB_ID</var>
        },
        'rowIndex': 0,
        'columnIndex': 0
      },
      'insertRight': True
    },
}
]

result = service.documents().batchUpdate(documentId=<var>DOCUMENT_ID</var>, body={'requests': requests}).execute()

একটি কলাম মুছে ফেলার জন্য, DeleteTableColumnRequest ব্যবহার করুন। পূর্বে একটি কলাম যোগ করার জন্য যেমন দেখানো হয়েছিল, ঠিক সেভাবেই আপনাকে টার্গেট কলামের মধ্যে সেলের অবস্থান নির্দিষ্ট করতে হবে।

টেবিলের সেল থেকে বিষয়বস্তু পড়া

একটি টেবিল সেলে কাঠামোগত উপাদানের একটি তালিকা থাকে; এই কাঠামোগত উপাদানগুলোর প্রতিটিই টেক্সটসহ একটি প্যারাগ্রাফ বা অন্য কোনো ধরনের কাঠামো হতে পারে—এমনকি আরেকটি টেবিলও। টেবিলের বিষয়বস্তু পড়ার জন্য, আপনি প্রতিটি উপাদানকে রিকার্সিভলি পরীক্ষা করতে পারেন, যেমনটি 'এক্সট্র্যাক্ট টেক্সট' অংশে দেখানো হয়েছে।

টেবিলের সেলগুলিতে বিষয়বস্তু সন্নিবেশ করা

টেবিলের কোনো সেলে লিখতে, আপনি যে সেলটি আপডেট করতে চান তার ভেতরের কোনো ইনডেক্সে একটি InsertTextRequest ব্যবহার করুন। আপডেট করা টেক্সটের জন্য টেবিলের ইনডেক্সগুলো স্বয়ংক্রিয়ভাবে পরিবর্তিত হয়ে যায়। DeleteContentRangeRequest ব্যবহার করে সেলের টেক্সট মুছে ফেলার ক্ষেত্রেও একই নিয়ম প্রযোজ্য।

কলামের বৈশিষ্ট্য পরিবর্তন করা

UpdateTableColumnPropertiesRequest আপনাকে একটি টেবিলের এক বা একাধিক কলামের বৈশিষ্ট্যগুলো পরিবর্তন করার সুযোগ দেয়।

আপনাকে অবশ্যই টেবিলের শুরুর ইনডেক্স এবং একটি TableColumnProperties অবজেক্ট প্রদান করতে হবে। শুধুমাত্র নির্বাচিত কলামগুলো পরিবর্তন করতে, অনুরোধে কলাম নম্বরগুলোর একটি তালিকা অন্তর্ভুক্ত করুন; টেবিলের সমস্ত কলাম পরিবর্তন করতে, একটি খালি তালিকা প্রদান করুন।

নিম্নলিখিত উদাহরণটি একটি টেবিলের কলামের প্রস্থ আপডেট করে, যেখানে প্রথমে সমস্ত কলামের প্রস্থ ১০০pt এবং তারপর প্রথম কলামের প্রস্থ ২০০pt নির্ধারণ করা হয়:

জাভা

List<Request> requests = new ArrayList<>();
requests.add(
    new Request()
        .setUpdateTableColumnProperties(
            new UpdateTableColumnPropertiesRequest()
                .setTableStartLocation(
                    new Location()
                        .setIndex(2)
                        .setTabId(<var>TAB_ID</var>))
                .setColumnIndices(null)
                .setTableColumnProperties(
                    new TableColumnProperties()
                        .setWidthType("FIXED_WIDTH")
                        .setWidth(
                            new Dimension().setMagnitude(100d).setUnit("PT")))
                .setFields("*")));

List<Integer> columnIndices = new ArrayList<>();
columnIndices.add(0);
requests.add(
    new Request()
        .setUpdateTableColumnProperties(
            new UpdateTableColumnPropertiesRequest()
                .setTableStartLocation(
                    new Location()
                        .setIndex(2)
                        .setTabId(<var>TAB_ID</var>))
                .setColumnIndices(columnIndices)
                .setTableColumnProperties(
                    new TableColumnProperties()
                        .setWidthType("FIXED_WIDTH")
                        .setWidth(
                            new Dimension().setMagnitude(200d).setUnit("PT")))
                .setFields("*")));

BatchUpdateDocumentRequest body =
    new BatchUpdateDocumentRequest().setRequests(requests);
BatchUpdateDocumentResponse response =
    docsService.documents().batchUpdate(<var>DOCUMENT_ID</var>, body).execute();

পাইথন

requests = [{
  'updateTableColumnProperties': {
    'tableStartLocation': {'index': 2, 'tabId': <var>TAB_ID</var>},
    'columnIndices': [],
    'tableColumnProperties': {
      'widthType': 'FIXED_WIDTH',
      'width': {
        'magnitude': 100,
        'unit': 'PT'
      }
    },
    'fields': '*'
  },
  'updateTableColumnProperties': {
    'tableStartLocation': {'index': 2, 'tabId': <var>TAB_ID</var>},
    'columnIndices': [0],
    'tableColumnProperties': {
      'widthType': 'FIXED_WIDTH',
      'width': {
        'magnitude': 200,
        'unit': 'PT'
      }
    },
    'fields': '*'
  },
}
]

result = service.documents().batchUpdate(documentId=<var>DOCUMENT_ID</var>, body={'requests': requests}).execute()

সারি শৈলী পরিবর্তন করা

UpdateTableRowsStyleRequest আপনাকে একটি টেবিলের এক বা একাধিক সারির স্টাইল পরিবর্তন করার সুযোগ দেয়।

আপনাকে অবশ্যই একটি TableRowStyle অবজেক্টের সাথে টেবিলের শুরুর ইনডেক্স প্রদান করতে হবে। শুধুমাত্র নির্বাচিত সারিগুলো পরিবর্তন করতে, অনুরোধে সারি নম্বরের একটি তালিকা অন্তর্ভুক্ত করুন; টেবিলের সমস্ত সারি পরিবর্তন করতে, একটি খালি তালিকা প্রদান করুন।

নিম্নলিখিত উদাহরণটি একটি টেবিলের ৩ নং সারির সর্বনিম্ন উচ্চতা নির্ধারণ করে:

জাভা

List<Integer> rowIndices = new ArrayList<>();
rowIndices.add(3);

List<Request> requests = new ArrayList<>();
requests.add(
    new Request()
        .setUpdateTableRowStyle(
            new UpdateTableRowStyleRequest()
                .setTableStartLocation(
                    new Location()
                        .setIndex(2)
                        .setTabId(<var>TAB_ID</var>))
                .setRowIndices(rowIndices)
                .setTableRowStyle(
                    new TableRowStyle()
                        .setMinRowHeight(
                            new Dimension().setMagnitude(18d).setUnit("PT")))
                .setFields("*")));

BatchUpdateDocumentRequest body =
    new BatchUpdateDocumentRequest().setRequests(requests);
BatchUpdateDocumentResponse response =
    docsService.documents().batchUpdate(<var>DOCUMENT_ID</var>, body).execute();

পাইথন

requests = [{
    'updateTableRowStyle': {
        'tableStartLocation': {'index': 2, 'tabId': <var>TAB_ID</var>},
        'rowIndices': [3],
        'tableRowStyle': {
            'minRowHeight': {
              'magnitude': 18,
              'unit': 'PT'
            }
        },
        'fields': '*'
    },
}
]

result = service.documents().batchUpdate(documentId=<var>DOCUMENT_ID</var>, body={'requests': requests}).execute()