import pdfplumber
#全是None
with pdfplumber.open(r"C:\Users\yjiang3\Desktop\Inv.pdf") as pdf:
table_page = pdf.pages[0]
table_page = pdf.pages[1]
table = table_page.extract_table(
table_settings={
"vertical_strategy": "text",
"horizontal_strategy": "text"
})
print(table)
import pdfplumber
from openpyxl import Workbook
#全是None
with pdfplumber.open(r"C:\Users\yjiang3\Desktop\32.pdf") as pdf:
table_page = pdf.pages[262]
table = table_page.extract_table(
table_settings={
"vertical_strategy": "text",
"horizontal_strategy": "text"
})
workbook = Workbook()
sheet = workbook.active
for row in table:
sheet.append(row)
workbook.save(r"C:\Users\yjiang3\Desktop\11.xlsx")
import pdfplumber
from openpyxl import Workbook
#全是None
with pdfplumber.open(r"C:\Users\yjiang3\Desktop\Inv.pdf") as pdf:
table_page = pdf.pages[1] table = table_page.extract_table(
table_settings={
"vertical_strategy": "text",
"horizontal_strategy": "text"
})
workbook = Workbook()
sheet = workbook.active
for row in table:
if not ''.join([str(item) for item in row]) == '': #去掉空行
sheet.append(row) workbook.save(r"C:\Users\yjiang3\Desktop\13.xlsx")
import pdfplumber
from openpyxl import Workbook
#全是None
with pdfplumber.open(r"C:\Users\yjiang3\Desktop\40.pdf") as pdf:
table_page = pdf.pages[38]
table = table_page.extract_table(
table_settings={
"vertical_strategy": "text",
"horizontal_strategy": "text"
})
workbook = Workbook()
sheet = workbook.active
for row in table:
if not ''.join([str(item) for item in row]) == '': #去掉空行
new_row = []
new_row.append(''.join([str(item) if item else '' for item in row[:4]]))
new_row += row[4:]
sheet.append(new_row) workbook.save(r"C:\Users\yjiang3\Desktop\12.xlsx")
import pdfplumber
from openpyxl import Workbook
with pdfplumber.open(r"C:\Users\yjiang3\Desktop\Inv.pdf") as pdf:
table_page = pdf.pages[1]
table = table_page.extract_table(
table_settings={
"vertical_strategy": "text",
"horizontal_strategy": "text"
})
workbook = Workbook()
sheet = workbook.active
for row in table:
if not ''.join([str(item) for item in row]) == '': #去掉空行
new_row = []
new_row.append(''.join([str(item) if item else '' for item in row[:6]]))
new_row += row[6:]
sheet.append(new_row)
workbook.save(r"C:\Users\yjiang3\Desktop\13.xlsx")
import pdfplumber
from openpyxl import Workbook
#全是None
with pdfplumber.open(r"C:\Users\yjiang3\Desktop\40.pdf") as pdf:
table_page = pdf.pages[40]
table = table_page.extract_table(
table_settings={
"vertical_strategy": "text",
"horizontal_strategy": "text"
})
workbook = Workbook()
sheet = workbook.active
for row in table:
if not ''.join([str(item) for item in row]) == '': #去掉空行
new_row = []
new_row.append(''.join([str(item) if item else '' for item in row[:4]]))
new_row += row[4:]
sheet.append(new_row) workbook.save(r"C:\Users\yjiang3\Desktop\20.xlsx")

PDF转置的更多相关文章

  1. 将excel文件批量转成pdf

    防止数据编辑.改动带来的不一致性,常常要将excel文件转成pdf文件再共享.发送给对方.有时excel文件还挺多,手头上保存实在是太慢了.就考虑用VBA批量转置. 掌握几个东西,就比较容易了: 1. ...

  2. C#给PDF文档添加文本和图片页眉

    页眉常用于显示文档的附加信息,我们可以在页眉中插入文本或者图形,例如,页码.日期.公司徽标.文档标题.文件名或作者名等等.那么我们如何以编程的方式添加页眉呢?今天,这篇文章向大家分享如何使用了免费组件 ...

  3. 在线浏览PDF之PDF.JS (附demo)

    平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html#skill 下载地址:http://mozilla.gith ...

  4. .NET平台开源项目速览(16)C#写PDF文件类库PDF File Writer介绍

    1年前,我在文章:这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)中(第9个项目),给大家推荐了一个开源免费的PDF读写组件 PDFSharp,PDFSharp我2年前就看过 ...

  5. C#如何在PDF文件添加图片印章

    文档中添加印章可以起一定的作用,比如,防止文件随意被使用,或者确保文档内容的安全性和权威性.C#添加图片印章其实也有很多实现方法,这里我使用的是免费的第三方软件Free Spire.PDF,向大家阐述 ...

  6. C#中如何创建PDF网格并插入图片

    这篇文章我将向大家演示如何以编程的方式在PDF文档中创建一个网格,并将图片插入特定的网格中. 网上有一些类似的解决方法,在这里我选择了一个免费版的PDF组件.安装控件后,创建新项目,添加安装目录下的d ...

  7. 在Asp.Net中操作PDF – iTextSharp - 使用表格

    使用Asp.Net生成PDF最常用的元素应该是表格,表格可以帮助比如订单或者发票类型的文档更加格式化和美观.本篇文章并不会深入探讨表格,仅仅是提供一个使用iTextSharp生成表格的方法介绍 使用i ...

  8. 开源免费且稳定实用的.NET PDF打印组件itextSharp(.NET组件介绍之八)

    在这个.NET组件的介绍系列中,受到了很多园友的支持,一些园友(如:数据之巅. [秦时明月]等等这些大神 )也给我提出了对应的建议,我正在努力去改正,有不足之处还望大家多多包涵.在传播一些简单的知识的 ...

  9. ASP.Net MVC——使用 ITextSharp 完美解决HTML转PDF(中文也可以)

    前言: 最近在做老师交代的一个在线写实验报告的小项目中,有这么个需求:把学生提交的实验报告(HTML形式)直接转成PDF,方便下载和打印. 以前都是直接用rdlc报表实现的,可这次牵扯到图片,并且更为 ...

  10. 在禅道中实现WORD等OFFICE文档转换为PDF进行在线浏览

    条件: 安装好禅道的服务器 能直接浏览PDF的浏览器(或通过 安装插件实现 ) 文档转换服务程序(建议部署在另一台服务器上)     实现 原理: 修改禅道的文件预览功能(OFFICE文档其使用的是下 ...

随机推荐

  1. Intel oneAPI 环境变量设置

    因工作需要,需要在linux系统配置多个不同环境的库,需要使用environment-modules工具管理环境变量,为保持配置方法的一致性,也使用modulefile文件加载Intel oneAPI ...

  2. js 评论时间换算

    //时间戳换算 let dateTime=2020-10-10 10:10:10 getDateDiff(dateTime){ let dateTimeStamp = new Date(dateTim ...

  3. AndroidStudio 集成kotlin,以及Kotlin-gradle-plugin-1.5.0.jar 下载失败

    配置Kotlin buildscript { ext.kotlin_version = '1.5.0' repositories { maven{url 'http://maven.aliyun.co ...

  4. https原理(五)双向实践(https代理)

    本文为了证明: 1 双向可以通过直接转发tcp的中间人代理网关 2 双向可以防止明文中间人 开始.(服务端need,使用myhost.com-pub-capub.jks,myhost.com-pub- ...

  5. TODO留学小程序,展开,收起失效

    text设置user-select=true后,display: -webkit-box 失效? https://developers.weixin.qq.com/community/develop/ ...

  6. Python用telnet设置,抓UDP抓采样点并显示

    ====main.bat==== echo off rem "d:\Program\WiresharkPortable64\App\Wireshark\tshark.exe" -- ...

  7. Java基于springboot大学生宿舍寝室考勤人脸识别管理系统

    简介 Java基于springboot开发的大学生寝室管理系统宿舍管理系统.学生可以查找寝室和室友信息,可以申请换寝室,申请维修,寝室长提交考勤信息(宿管确认学生考勤信息),补签,查看寝室通报,宿管信 ...

  8. composer更新报错

    在用composer安装Yii2的扩展插件时,报错: [UnexpectedValueException] Could not parse version constraint <=2.*: I ...

  9. List list = new ArrayList()为何父类引用指向子类对象(多态)

    转自--https://blog.csdn.net/Jae_Peng/article/details/80151033 不习惯用csdn,博客园没有搜到类似的,摘录过来. 多态:要有继承,方法的重写, ...

  10. 安装.msi格式安装包

    msi格式的文件,点右键后,没有"以管理员身份运行"的菜单项,直接运行.msi文件报错:"There is a problem with this Windows Ins ...