Interfejs Google Docs API umożliwia wstawianie i usuwanie tekstu w dokumencie. Przenoszenie tekstu obejmuje obie operacje, poprzedzone get
treści.
Możesz wstawiać i usuwać tekst w dowolnym segmencie karty dokumentu (treść, nagłówek, stopka lub przypis).
Wstaw tekst
Aby wstawić tekst do dokumentu, użyj metody
documents.batchUpdate
i dołącz
InsertTextRequest
z tekstem i lokalizacją jako ładunek.
Poniższy przykładowy kod pokazuje, jak wstawić serię ciągów tekstowych w określonych lokalizacjach indeksu w treści dokumentu. W przykładzie użyto 3 przesunięć docelowych (25, 50 i 75) i w każdym z tych miejsc wstawiono 10-znakowy ciąg.
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 wszystkie indeksy o wyższych numerach o rozmiar wstawionego tekstu. W przykładzie wstępnie obliczany jest wynik tych zmian indeksu, dzięki czemu kolejne wstawienia są wykonywane z nowym, skorygowanym przesunięciem. Aby wstawić znaki w oryginalnych przesunięciach docelowych 25, 50 i 75, rzeczywiste indeksy wstawiania to:
- Pierwsze wstawienie dodaje 10 znaków na pozycji 25.
- Drugie wstawienie dodaje 10 znaków na pozycji 50+10=60.
- Trzecie wstawienie dodaje 10 znaków na pozycji 75+10+10=95.
Usuń tekst
Aby usunąć tekst z dokumentu, najpierw utwórz Range
, który określa zakres tekstu do usunięcia. Następnie użyj metody documents.batchUpdate
i dodaj DeleteContentRangeRequest
.
Poniższy przykładowy kod pokazuje, jak usunąć tekst między indeksem 10 a indeksem 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ść sprawę, pisząc od tyłu. Podobnie jak w przypadku wstawiania, usuwanie tekstu zmienia indeksy całego tekstu „poniżej” w segmencie. Ponownie pisanie od tyłu może uprościć obsługę indeksów.
Przenoszenie tekstu
Aby przenieść tekst, usuń go z jednego miejsca, a następnie wstaw w innym. Usunięcie treści nie powoduje utworzenia ich kopii (nie ma odpowiednika schowka), więc najpierw musisz wyodrębnić zawartość zakresu, aby móc użyć jej w prośbie o wstawienie tekstu.
Powiązane artykuły
- Tworzenie dokumentów i zarządzanie nimi
- Scalanie tekstu w dokumencie
- Struktura dokumentu w Dokumentach Google