Interfejs API Dokumentów Google umożliwia wstawianie i usuwanie tekstu w dokumencie. Przenoszenie tekstu
obejmuje obie operacje, poprzedzone znakiem get
treści.
W dowolnym dokumencie możesz wstawić lub usunąć tekst segmentów dostępnych na karcie (treść, nagłówek, stopka lub przypis).
Wstaw tekst
Aby wstawić tekst do dokumentu, użyj
documents.batchUpdate
i dodaj atrybut
InsertTextRequest
z tekstem i lokalizacją jako ładunkiem.
Poniższa próbka kodu pokazuje, jak można wstawić serię ciągów tekstowych w określonych lokalizacji indeksów w treści dokumentu. W przykładzie użyto trzech miejsca docelowego (25, 50 i 75) oraz wstawia ciąg dziesięcioznakowy przy każdym lokalizacji.
Java
List<Request> requests = new ArrayList<>(); requests.add(new Request().setInsertText(new InsertTextRequest() .setText(text1) .setLocation(new Location().setIndex(25).setTabId(TAB_ID)))); requests.add(new Request().setInsertText(new InsertTextRequest() .setText(text2) .setLocation(new Location().setIndex(50).setTabId(TAB_ID)))); requests.add(new Request().setInsertText(new InsertTextRequest() .setText(text3) .setLocation(new Location().setIndex(75).setTabId(TAB_ID)))); BatchUpdateDocumentRequest body = new BatchUpdateDocumentRequest().setRequests(requests); BatchUpdateDocumentResponse response = docsService.documents() .batchUpdate(DOCUMENT_ID, body).execute();
PHP
$requests = array(); $requests[] = new Google_Service_Docs_Request(array( 'insertText' => array( 'text' => $text1, 'location' => array( 'index' => 25, 'tabId' => TAB_ID, ), ), 'insertText' => array( 'text' => $text2, 'location' => array( 'index' => 50, 'tabId' => TAB_ID, ), ), 'insertText' => array( 'text' => $text3, 'location' => array( 'index' => 75, 'tabId' => TAB_ID, ), ), )); $batchUpdateRequest = new Google_Service_Docs_BatchUpdateDocumentRequest(array( 'requests' => $requests )); $response = $service->documents->batchUpdate($documentId, $batchUpdateRequest);
Python
requests = [ { 'insertText': { 'location': { 'index': 25, 'tabId': TAB_ID }, 'text': text1 } }, { 'insertText': { 'location': { 'index': 50, 'tabId': TAB_ID }, 'text': text2 } }, { 'insertText': { 'location': { 'index': 75, 'tabId': TAB_ID }, 'text': text3 } }, ] result = service.documents().batchUpdate( documentId=DOCUMENT_ID, body={'requests': requests}).execute()
Każde wstawienie zwiększa wartości wszystkich indeksów o wyższych numerach o rozmiar wstawiony tekst. W przykładzie podano wstępnie wynik zmian indeksu, więc że kolejne wstawienia mają miejsce z nowym, skorygowanym przesunięciem. W ten sposób przy pierwotnym przesunięciem docelowym wynoszącym 25, 50 i 75, rzeczywiste indeksy wstawiania to:
- Pierwsze wstawienie powoduje dodanie 10 znaków w pozycji 25.
- Po drugie wstawienie dodaje 10 znaków w pozycji 50+10=60.
- Trzecie wstawienie powoduje dodanie 10 znaków w pozycji 75+10+10=95.
Usuwanie tekstu
Aby usunąć tekst z dokumentu, najpierw utwórz
Range
, który definiuje zakres
tekst do usunięcia. Następnie użyj metody documents.batchUpdate
i dołącz
DeleteContentRangeRequest
Poniższy przykładowy kod pokazuje, jak usunąć tekst między indeksem 10 i indeksu 24 w treści dokumentu.
Java
List<Request> requests = new ArrayList<>(); requests.add(new Request().setDeleteContentRange( new DeleteContentRangeRequest() .setRange(new Range() .setStartIndex(10) .setEndIndex(24) .setTabId(TAB_ID)) )); BatchUpdateDocumentRequest body = new BatchUpdateDocumentRequest().setRequests(requests); BatchUpdateDocumentResponse response = docsService.documents() .batchUpdate(DOCUMENT_ID, body).execute();
PHP
$requests = array(); $requests[] = new Google_Service_Docs_Request(array( 'deleteContentRange' => array( 'range' => array( 'startIndex' => 10, 'endIndex' => 24, 'tabId' => TAB_ID ), ), )); $batchUpdateRequest = new Google_Service_Docs_BatchUpdateDocumentRequest(array( 'requests' => $requests )); $response = $service->documents->batchUpdate($documentId, $batchUpdateRequest);
Python
requests = [ { 'deleteContentRange': { 'range': { 'startIndex': 10, 'endIndex': 24, 'tabId': TAB_ID } } }, ] result = service.documents().batchUpdate( documentId=DOCUMENT_ID, body={'requests': requests}).execute()
Uprość sprawy, zapisując je wstecz. Tak jak w przypadku wstawiania, usuwanie tekst zmienia indeksy całego tekstu „poniżej” w segmencie odbiorców. Jak już wspomnieliśmy, pisanie wstecz może uprościć obsługę indeksów.
Przenieś tekst
Aby przenieść tekst, usuń go w jednym miejscu, a następnie wstaw w inne miejsce. Usunięcie treści nie powoduje utworzenia ich kopii (nie ma analogicznego pojęcia ze schowka), więc musisz najpierw wyodrębnić zawartość zakresu, aby móc używać w żądaniu wstawiania tekstu.
Powiązane artykuły
- Tworzenie dokumentów i zarządzanie nimi
- Scalanie tekstu w dokument
- Struktura dokumentu w Dokumentach Google