Как я могу вернуть данные файла msword в Python / Flask для рендеринга в iframe или встроить их для предварительного просмотра? - PullRequest
0 голосов
/ 22 января 2020

Я пытаюсь отобразить (просмотреть) сохраненный файл Word или PDF в HTML из каталога проекта.

Например, у меня есть пользователь, чье резюме хранится в его аккаунте. Теперь я хочу дать ему предварительный просмотр своего резюме на странице своего аккаунта. Это может быть сделать c, DOCX или PDF. Как я могу вернуть данные msword или pdf в Python / Flask, чтобы они могли отображаться в HTML / Jinja2 либо в iframe, либо встраиваться. Вот мой код

from flask import render_template, url_for, flash, redirect, request, abort, jsonify,session, send_file
import os
import mimetypes

@app.route("/account", methods=['GET', 'POST'])
@login_required
def account():

    resume = current_user.resume
    resumefile = downloadresume()
    return render_template('account.html', pagetitle='Account', profile_pic=profile_pic, form=form, resume=resume, resumefile = resumefile)

@app.route("/account/downloadresume", methods=['GET', 'POST'])
def downloadresume():
    filename = current_user.resume
    mime = mimetypes.MimeTypes().guess_type(filename)[0] 
    if mime in ["application/vnd.openxmlformats-officedocument.wordprocessingml.document","application/msword"]:
        # return filename.data
        return send_file(resume.data, as_attachment=False)

Джинджа / HTML

<iframe src="{{ resumefile }}"></iframe>

Ответы [ 2 ]

1 голос
/ 22 января 2020

Я не уверен насчет документов Word, но я знаю, что библиотека PDF js сможет загрузить PDF-файл и отобразить его на холсте.

Пример его использование можно найти здесь: https://jsfiddle.net/pdfjs/9engc9mw/

// If absolute URL from the remote server is provided, configure the CORS
// header on that server.
var url = 'https://raw.githubusercontent.com/mozilla/pdf.js/ba2edeae/examples/learning/helloworld.pdf';

// Loaded via <script> tag, create shortcut to access PDF.js exports.
var pdfjsLib = window['pdfjs-dist/build/pdf'];

// The workerSrc property shall be specified.
pdfjsLib.GlobalWorkerOptions.workerSrc = '//mozilla.github.io/pdf.js/build/pdf.worker.js';

// Asynchronous download of PDF
var loadingTask = pdfjsLib.getDocument(url);
loadingTask.promise.then(function(pdf) {
  console.log('PDF loaded');
  
  // Fetch the first page
  var pageNumber = 1;
  pdf.getPage(pageNumber).then(function(page) {
    console.log('Page loaded');
    
    var scale = 1.5;
    var viewport = page.getViewport({scale: scale});

    // Prepare canvas using PDF page dimensions
    var canvas = document.getElementById('the-canvas');
    var context = canvas.getContext('2d');
    canvas.height = viewport.height;
    canvas.width = viewport.width;

    // Render PDF page into canvas context
    var renderContext = {
      canvasContext: context,
      viewport: viewport
    };
    var renderTask = page.render(renderContext);
    renderTask.promise.then(function () {
      console.log('Page rendered');
    });
  });
}, function (reason) {
  // PDF loading error
  console.error(reason);
});
#the-canvas {
  border:1px solid black;
}
<script src="//mozilla.github.io/pdf.js/build/pdf.js"></script>

<h1>PDF.js 'Hello, world!' example</h1>

<canvas id="the-canvas"></canvas>

Поскольку это сделано во внешнем интерфейсе, вам просто нужно убедиться, что файл PDF доступен. С файлами Word я уверен, что вы можете конвертировать их в PDF, однако вы можете потерять некоторые функции.

0 голосов
/ 22 января 2020

Есть 2 возможных пути к этому. У вас нет одного метода для рендеринга файлов PDF и DOCX.

Для файлов PDF:

  • Вы можете использовать метод, указанный @MichaelBauer, или Поместите гиперссылку, которая указывает на файл PDF в каталоге. Все текущие браузеры имеют возможность рендерить файлы PDF из любого автономного или онлайн-каталога.

Для файлов DOCX

  • Вам необходимо конвертировать DOCX файл в файл PDF, чтобы рендеринг стал проще. А затем следуйте процессу рендеринга преобразованного PDF. Что касается плавного преобразования pdf в docx, у вас есть служба Adobe Cloud Cloud SDK.
...