當前位置: 首頁>>代碼示例>>Python>>正文


Python fitz.open方法代碼示例

本文整理匯總了Python中fitz.open方法的典型用法代碼示例。如果您正苦於以下問題:Python fitz.open方法的具體用法?Python fitz.open怎麽用?Python fitz.open使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在fitz的用法示例。


在下文中一共展示了fitz.open方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: open_document

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def open_document(doc_fname):
    """Return the document opened by fitz (PyMuPDF)."""
    # TODO: Move the get_filename call to main_pdfCropMargins or
    # similar if actually used.
    if not doc_fname:
        doc_fname = get_filename()
    try:
        document = fitz.open(doc_fname)
    except RuntimeError:
        print("\nError in pdfCropMargins: The PyMuPDF program could not read"
              " the document\n   '{}'\nin order to display it in the GUI.   If you have"
              " Ghostscript installed\nconsider running pdfCropMargins with the"
              " '--gsFix' option to attempt to repair it."
              .format(doc_fname), file=sys.stderr)
        ex.cleanup_and_exit(1)
    page_count = len(document)
    return document, page_count 
開發者ID:abarker,項目名稱:pdfCropMargins,代碼行數:19,代碼來源:gui.py

示例2: decrypt_doc

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def decrypt_doc(self):
        # let user enter document password
        pw = None
        dlg = wx.TextEntryDialog(self, 'Please enter password below:',
                 'Document needs password to open', '',
                 style = wx.TextEntryDialogStyle|wx.TE_PASSWORD)
        while pw is None:
            rc = dlg.ShowModal()
            if rc == wx.ID_OK:
                pw = str(dlg.GetValue().encode("utf-8"))
                self.doc.authenticate(pw)
            else:
                return
            if self.doc.isEncrypted:
                pw = None
                dlg.SetTitle("Wrong password. Enter correct one or cancel.")
        return

#==============================================================================
# main program
#------------------------------------------------------------------------------
# Show a standard FileSelect dialog to choose a file for display
#==============================================================================
# Wildcard: offer all supported filetypes for display 
開發者ID:pymupdf,項目名稱:PyMuPDF-Utilities,代碼行數:26,代碼來源:PDFdisplay.py

示例3: decrypt_doc

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def decrypt_doc(self):
        # let user enter document password
        pw = None
        dlg = wx.TextEntryDialog(self, 'Please Enter Password',
                 'Document needs password to open', '',
                 style = wx.TextEntryDialogStyle|wx.TE_PASSWORD)
        while pw is None:
            rc = dlg.ShowModal()
            if rc == wx.ID_OK:
                pw = str(dlg.GetValue().encode("utf-8"))
                self.doc.authenticate(pw)
            else:
                return
            if self.doc.isEncrypted:
                pw = None
                dlg.SetTitle("Wrong password. Enter correct one or cancel.")
        return

#==============================================================================
# main program
#------------------------------------------------------------------------------
# Show a standard FileSelect dialog to choose a file
#==============================================================================
# Wildcard: only offer PDF files 
開發者ID:pymupdf,項目名稱:PyMuPDF-Utilities,代碼行數:26,代碼來源:PDFLinkMaint.py

示例4: make_page

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def make_page(beta):
    """Create a dummy PDF with a page, put in a box filled with above text,
    and also insert some explanation. Then rotate the text box around
    its top-left corner by given angle beta. The resulting page's image
    is returned as a PNG stream, and the PDF discarded again.
    This functions execution time determines the overall "frames" per
    second ration.
    """
    doc = fitz.open()
    page = doc.newPage(width=pagerect.width, height=pagerect.height)
    mat = fitz.Matrix(beta)
    img = page.newShape()
    img.drawRect(r)
    img.finish(fill=gold, color=blue, width=0.3, morph=(r.tl, mat))
    img.insertText(textpoint, itext % beta, fontname="cobo", fontsize=20)
    img.insertTextbox(r, text, fontsize=15, rotate=90, morph=(r.tl, mat))
    img.commit()
    pix = page.getPixmap(alpha=False)
    return pix.getImageData("pgm")


# ------------------------------------------------------------------------------
# main program
# ------------------------------------------------------------------------------ 
開發者ID:pymupdf,項目名稱:PyMuPDF-Utilities,代碼行數:26,代碼來源:morph-demo1.py

示例5: make_page

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def make_page(beta):
    """Create a dummy PDF with a page, put in a box filled with above text,
    and also insert some explanation. Then x-shear the text box around
    its top-left corner by given value beta. The resulting page's image
    is returned as a PNG stream, and the PDF discarded again.
    This functions execution time determines the overall "frames" per
    second ration.
    """
    doc = fitz.open()
    page = doc.newPage(width=pagerect.width, height=pagerect.height)
    mat = fitz.Matrix(beta * 0.01, 0, 1)
    img = page.newShape()
    img.drawRect(r)
    img.finish(fill=gold, color=blue, width=0.3, morph=(r.tl, mat))
    img.insertText(textpoint, itext % (beta * 0.01), fontname="cobo", fontsize=20)
    img.insertTextbox(r, text, fontsize=15, rotate=90, morph=(r.tl, mat))
    img.commit()
    pix = page.getPixmap(alpha=False)
    return pix.getImageData("pgm")


# ------------------------------------------------------------------------------
# main program
# ------------------------------------------------------------------------------ 
開發者ID:pymupdf,項目名稱:PyMuPDF-Utilities,代碼行數:26,代碼來源:morph-demo2.py

示例6: setIcon

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def setIcon(self, fname):
        # 打開 PDF
        doc = fitz.open(fname)
        # 加載封麵
        page = doc.loadPage(0)
        # 生成封麵圖像
        cover = render_pdf_page(page, True)
        label = QLabel(self)
        # 設置圖片自動填充 label
        label.setScaledContents (True)
        # 設置封麵圖片
        label.setPixmap(QPixmap(cover))
        # 設置單元格元素為 label
        self.table.setCellWidget(self.x, self.y, label)
        # 刪除 label 對象,防止後期無法即時刷新界麵
        # 因為 label 的生存周期未結束
        del label
        # 設置當前行數與列數
        self.crow, self.ccol = self.x, self.y
        # 每 8 個元素換行
        if (not self.y % 7) and (self.y):
            self.x += 1
            self.y = 0
        else:
            self.y += 1 
開發者ID:xflywind,項目名稱:Python-Application,代碼行數:27,代碼來源:__main__.py

示例7: read_book

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def read_book(self):
        self.book = fitz.open(self.filename) 
開發者ID:BasioMeusPuga,項目名稱:Lector,代碼行數:4,代碼來源:pdf.py

示例8: update_model

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def update_model(self):
        # We're updating the underlying model to have real-time
        # updates on the read status

        # Set a baseline model index in case the item gets deleted
        # E.g It's open in a tab and deleted from the library
        model_index = None
        start_index = self.main_window.lib_ref.libraryModel.index(0, 0)

        # Find index of the model item that corresponds to the tab
        model_index = self.main_window.lib_ref.libraryModel.match(
            start_index,
            QtCore.Qt.UserRole + 6,
            self.pw.parent.metadata['hash'],
            1, QtCore.Qt.MatchExactly)

        if self.are_we_doing_images_only:
            position_percentage = (
                self.pw.parent.metadata['position']['current_chapter'] /
                self.pw.parent.metadata['position']['total_chapters'])
        else:
            position_percentage = (
                self.pw.parent.metadata['position']['current_block'] /
                self.pw.parent.metadata['position']['total_blocks'])

        # Update position percentage
        if model_index:
            self.main_window.lib_ref.libraryModel.setData(
                model_index[0], position_percentage, QtCore.Qt.UserRole + 7) 
開發者ID:BasioMeusPuga,項目名稱:Lector,代碼行數:31,代碼來源:contentwidgets.py

示例9: get_filename

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def get_filename():
    """Get the filename of the PDF file via GUI if one was not passed in."""
    fname = sg.PopupGetFile("Select file and filetype to open:",
                            title="pdfCropMargins: Document Browser",
                            file_types=[ # Only PDF files.
                                          ("PDF Files", "*.pdf"),
                                       ],
                            )
    return fname # Might be None. 
開發者ID:abarker,項目名稱:pdfCropMargins,代碼行數:11,代碼來源:gui.py

示例10: auto_save

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def auto_save(self):
        f_toc = open(spad.file + ".json", "w")
        d = {"toc": self.tocgrid.Table.data,
             "author": self.ausaut.Value, "title": self.austit.Value,
             "subject": self.aussub.Value, "keywords": self.keywords.Value}
        json.dump(d, f_toc)
        f_toc.close()
        spad.lastsave = time.clock()
        return

#==============================================================================
# display a PDF page
#============================================================================== 
開發者ID:pymupdf,項目名稱:PyMuPDF-Utilities,代碼行數:15,代碼來源:PDFoutline.py

示例11: draw_links

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def draw_links(self):
        dc = wx.ClientDC(self.PDFimage)
        dc.SetPen(wx.Pen("BLUE", width=1))
        dc.SetBrush(wx.Brush("BLUE", style=wx.BRUSHSTYLE_TRANSPARENT))
        self.link_rects = []
        self.link_bottom_rects = []
        self.link_texts = []
        for lnk in self.page_links:
            if lnk.get("update", False):
                self.enable_update()
            wxr = self.Rect_to_wxRect(lnk["from"])
            dc.DrawRectangle(wxr[0], wxr[1], wxr[2], wxr[3])
            self.link_rects.append(wxr)
            p = wxr.BottomRight
            br = wx.Rect(p.x - self.sense, p.y - self.sense,
                         2*self.sense, 2*self.sense)
            self.link_bottom_rects.append(br)
            if lnk["kind"] == fitz.LINK_GOTO:
                if lnk["page"] >= 0:
                    txt = "page " + str(lnk["page"] + 1)
                else:
                    txt = "name " + str(lnk["to"])
            elif lnk["kind"] == fitz.LINK_GOTOR:
                txt = lnk["file"]
                if lnk["page"] >= 0:
                    txt += " p. " + str(lnk["page"] + 1)
                else:
                    txt += "(" + str(lnk["to"]) + ")"
            elif lnk["kind"] == fitz.LINK_URI:
                txt = lnk["uri"]
            elif lnk["kind"] == fitz.LINK_LAUNCH:
                txt = "open " + lnk["file"]
            elif lnk["kind"] == fitz.LINK_NONE:
                txt = "none"
            else:
                txt = "unkown destination"
            self.link_texts.append(txt)
        return 
開發者ID:pymupdf,項目名稱:PyMuPDF-Utilities,代碼行數:40,代碼來源:PDFLinkMaint.py

示例12: make_oval

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def make_oval(f):
    """Make a PDF page and draw an oval inside a Quad.
    The upper left and the lower right quad points and the fill color are
    subject to a passed-in parameter. Effectively, they exchange their position,
    thus causing changes to the drawn shape.
    The resulting page picture is passed back as a PNG image and the PDF is
    discarded again. The execution speed of this function mainly determines
    the number of "frames" shown per second.
    """
    doc = fitz.open()  # dummy PDF
    page = doc.newPage(width=400, height=400)  # page dimensions as you like
    r = page.rect + (4, 4, -4, -4)
    q = r.quad  # full page rect as a quad
    q1 = fitz.Quad(
        q.lr + (q.ul - q.lr) * f, q.ur, q.ll, q.ul + (q.lr - q.ul) * f  # upper left
    )  # lower right
    # make an entertaining fill color - simulating rotation around
    # a diagonal
    c1 = min(1, f)
    c3 = min(1, max(1 - f, 0))
    fill = (c1, 0, c3)
    page.drawOval(
        q1, color=(0, 0, 1), fill=fill, width=0.3  # blue border  # variable fill color
    )  # border width
    pix = page.getPixmap(alpha=False)  # make pixmap, no alpha
    doc.close()  # discard PDF again
    return pix.getImageData("pgm")  # return a data stream


# ------------------------------------------------------------------------------
# main program
# ------------------------------------------------------------------------------ 
開發者ID:pymupdf,項目名稱:PyMuPDF-Utilities,代碼行數:34,代碼來源:quad-show1.py

示例13: initUi

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def initUi(self):
        # 連接
        self._init_bookset()
        self.x = 0
        self.y = 0
        # 初始化
        self.crow = self.ccol = -1
        # 初始化表格類型
        self._set_table_style()
        # 將 toolbar + 號與 self.open 函數綁定
        self.addbar.triggered.connect(self.open)

    # 連接數據庫 
開發者ID:xflywind,項目名稱:Python-Application,代碼行數:15,代碼來源:__main__.py

示例14: open

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def open(self):
        # 打開文件
        fname = self.get_file()
        if self.filter_book(fname):
            self.set_icon(fname) 
開發者ID:xflywind,項目名稱:Python-Application,代碼行數:7,代碼來源:__main__.py

示例15: set_icon

# 需要導入模塊: import fitz [as 別名]
# 或者: from fitz import open [as 別名]
def set_icon(self, fname):
        # 打開 PDF
        doc = fitz.open(fname)
        # 加載封麵
        page = doc.loadPage(0)
        # 生成封麵圖像
        cover = render_pdf_page(page)
        label = QLabel(self)
        label.resize(self.width, self.width * 4 // 3)
        # 設置圖片自動填充 label
        label.setScaledContents(True)
        # 設置封麵圖片
        p = QPixmap(cover)
        p.scaled(self.width, self.width * 4 // 3, Qt.KeepAspectRatio)
        label.setPixmap(p)
        # 設置單元格元素為 label
        self.table.setCellWidget(self.x, self.y, label)
        # 刪除 label 對象,防止後期無法即時刷新界麵
        # 因為 label 的生存周期未結束
        del label
        # 設置當前行數與列數
        self.crow, self.ccol = self.x, self.y
        # 每 8 個元素換行
        if (not self.y % 7) and (self.y):
            self.x += 1
            self.y = 0
        else:
            self.y += 1 
開發者ID:xflywind,項目名稱:Python-Application,代碼行數:30,代碼來源:__main__.py


注:本文中的fitz.open方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。