我想在Google文档中选择 鼠标 中的单词或行,并通过脚本获取这些选定的单词或行。
示例:
var doc = DocumentApp.getActiveDocument();
var docText = doc.editAsText();
var text = docText.getSelection();
我试过,但我没有找到任何选择访问方法,如VBA。
答案 0 :(得分:6)
昨天添加了处理光标位置和所选文本的功能,解决了Issue 2865: Get current user location & state information in Document。另请参阅blog post。
事实证明,使用选择有一些技巧。我试图在这里展示它们 - 如果你找到其他人,请添加评论,我很乐意更新。
function onOpen() {
DocumentApp.getUi().createMenu('Selection')
.addItem("Report Selection", 'reportSelection' )
.addToUi();
}
function reportSelection () {
var doc = DocumentApp.getActiveDocument();
var selection = doc.getSelection();
var ui = DocumentApp.getUi();
var report = "Your Selection: ";
if (!selection) {
report += " No current selection ";
}
else {
var elements = selection.getSelectedElements();
// Report # elements. For simplicity, assume elements are paragraphs
report += " Paragraphs selected: " + elements.length + ". ";
if (elements.length > 1) {
}
else {
var element = elements[0].getElement();
var startOffset = elements[0].getStartOffset(); // -1 if whole element
var endOffset = elements[0].getEndOffsetInclusive(); // -1 if whole element
var selectedText = element.asText().getText(); // All text from element
// Is only part of the element selected?
if (elements[0].isPartial())
selectedText = selectedText.substring(startOffset,endOffset+1);
// Google Doc UI "word selection" (double click)
// selects trailing spaces - trim them
selectedText = selectedText.trim();
endOffset = startOffset + selectedText.length - 1;
// Now ready to hand off to format, setLinkUrl, etc.
report += " Selected text is: '" + selectedText + "', ";
report += " and is " + (elements[0].isPartial() ? "part" : "all") + " of the paragraph."
}
}
ui.alert( report );
}
答案 1 :(得分:3)
如果您想要检索已突出显示的文字,可以尝试...
function findHighlighted() {
var body = DocumentApp.getActiveDocument().getBody(),
bodyTextElement = body.editAsText(),
bodyString = bodyTextElement.getText(),
char, len;
for (char = 0, len = bodyString.length; char < len; char++) {
if (bodyTextElement.getBackgroundColor(char) == '#ffff00') // Yellow
Logger.log(bodyString.charAt(char))}
}
派生自Jonathan's I/O example。 但请注意,截至撰写本文时,working with cursor position and selections尚未提供。
更新: 光标选择现在可用,请参阅docs。
答案 2 :(得分:2)
你很亲密。我想你想要findText() method。
var text = docText.findText("some string of text in the document") // for example
我不熟悉VBA,但这样可以在文档中选择文本。
答案 3 :(得分:0)
为了增加Bryan的答案,我写了这个来转换单个字符以返回已突出显示的单词或短语数组。
function findHighlighted() {
var results = [];
var body = DocumentApp.getActiveDocument().getBody(),
bodyTextElement = body.editAsText(),
bodyString = bodyTextElement.getText(),
char, len;
for (char = 0, len = bodyString.length; char < len; char++) {
if (bodyTextElement.getBackgroundColor(char) !== null)
results.push([char, bodyString.charAt(char)]);
}
return results;
}
function getWords() {
var arr = findHighlighted();
var wordList = [];
var holding = [];
var nextNum, sum;
for (var i = 0; i < arr.length; i++) {
if (arr[i + 1] === undefined) {
nextNum = 0;
} else {
nextNum = arr[i + 1][0];
}
sum = (Number(arr[i][0]) + 1);
if (nextNum === sum) {
holding.push(arr[i][1]);
} else {
holding.push(arr[i][1]);
wordList.push(holding.join(""));
holding = [];
}
}
Logger.log(wordList);
}
答案 4 :(得分:-1)
function getHighlightedText() {
var selection = DocumentApp.getActiveDocument().getSelection();
if (selection) {
var elements = selection.getRangeElements();
for (var i = 0; i < elements.length; i++) {
var element = elements[i];
// Only modify elements that can be edited as text; skip images and other non-text elements.
if (element.getElement().editAsText) {
var text = element.getElement().editAsText();
return text;
}
}
}
}