办公室任务窗格中的应用:如何获得在OOXML字符串整个文件?(Office task pane ap

2019-10-23 01:53发布

我开发一个Office任务窗格的应用程序需要访问整个文档。 我知道有一个API getFileAsync() https://msdn.microsoft.com/en-us/library/office/jj220084.aspx

Office.context.document.getFileAsync(fileType [, options], callback);

然而, fileType只能是三个值: compressedpdftext

compressed

返回整个文档(.PPTX或.DOCX)中的Office Open XML(OOXML)格式作为一个字节数组。

pdf

返回PDF格式作为字节数组整个文档。

text

只返回文档作为一个字符串的文本。 (仅限Word)

当它被compressed时,返回值是一个字节数组。 我怎样才能得到一个OOXML字符串?

还是有一个文档中选择所有内容,这样我就可以使用一个API getSelectedDataAsync() API?

Answer 1:

如果有人发现这个线程,我设法解决这个使用zip.js 。

var dataByteArray = [];

function getDocumentAsOoxml() {
    Office.context.document.getFileAsync("compressed", { sliceSize: 100000 }, function (result) {
        if (result.status == Office.AsyncResultStatus.Succeeded) {
            // Get the File object from the result.
            var myFile = result.value;
            var state = {
                file: myFile,
                counter: 0,
                sliceCount: myFile.sliceCount
            };
            getSlice(state);
        }
    });
}

function getSlice(state) {
    state.file.getSliceAsync(state.counter, function (result) {
        if (result.status == Office.AsyncResultStatus.Succeeded) {
            readSlice(result.value, state);
        }
    });
}

function readSlice(slice, state) {
    var data = slice.data;
    // If the slice contains data, create an HTTP request.
    if (data) {
        dataByteArray = dataByteArray.concat(data);
        state.counter++;
        if (state.counter < state.sliceCount) {
            getSlice(state);
        } else {
            closeFile(state);
        }
    }
}

function closeFile(state) {
    // Close the file when you're done with it.
    state.file.closeAsync(function (result) { });

    // convert from byte array to blob that can bre read by zip.js
    var byteArray = new Uint8Array(dataByteArray);
    var blob = new Blob([byteArray]);

    // Load zip.js library
    $.getScript("/Scripts/zip.js/zip.js", function () {
        zip.workerScriptsPath = "/Scripts/zip.js/";
        // use a BlobReader to read the zip from a Blob object
        zip.createReader(new zip.BlobReader(blob), function (reader) {
            // get all entries from the zip file
            reader.getEntries(function (entries) {
                if (entries.length > 0) {
                    for (var i = 0; i < entries.length; i++) {
                        var entry = entries[i];
                        // find the file you are looking for
                        if (entry.filename == 'word/document.xml') {
                            entry.getData(new zip.TextWriter(), function (text) {

                                // text contains the entry data as a String
                                doSomethingWithText(text);

                                // close the zip reader
                                reader.close(function () {
                                    // onclose callback
                                });
                            }, function (current, total) {
                                // onprogress callback
                            });
                            break;
                        }
                    }
                }
            });
        }, function (error) {
            // onerror callback
        });
    });
}

但愿会有在未来一个更简单的方法。



Answer 2:

这是一个有点晚了。

我一直在与任务窗格应用程序最近和,事实证明,OOXML是本地压缩(除非我大错特错)。

我最好的建议是要弄清楚该字符串是在编码中的编码,并与编码类型解码。 我敢打赌,这是UTF-8。



文章来源: Office task pane app: how to get the whole document in an OOXml string?