ypzl药品质量不合格数据库-excel自动排版
原创:
qq:231469242
import xlrd
import pandas,numpy
import matplotlib.pyplot as plt
import pandas as pd
#参数
#报告时间
reportdate="2016/12/22"
#省份
admin="江西"
fileName="江西2016年第4期药品质量公告不符合规定药品汇总(假冒).xls"
year="2016年"
#文件名
file="江西2016年第4期药品质量公告不符合规定药品汇总"
url="http://www.jxda.gov.cn/ZWGK/ZWTG/ZLGG/2016/12/14761230.html"
#假冒设置为空值
fake=""
data = xlrd.open_workbook(fileName)
table = data.sheets()[0]
#获取行数和列数
nrows = table.nrows
ncols = table.ncols
#把excel数据转换为列为元素的列表
list_columns=[]
#A类,存储标签包含的关键字
#存储药品名称相关中文
list_title_names=['药品名称','检品名称','药品品名','品名','样品名称','标示药品名称']
#存储标示生产企业相关中文
list_title_manufacturers=['标示生产单位','标示生产企业','样品标示生产单位','标示生产企业名称']
#存储药标示批号相关中文
list_title_pitchnos=['标示批号','批号','生产批号','批件号','产品批号']
#存储药标示批号相关中文
list_title_specifications=['标示规格','规格','药品规格']
#存储不合格项目相关中文
list_title_unpasseditems=['不符合项目','不合格项目','不符合规定项目']
#存储有效期相关中文
list_title_validperiods=['有效期至']
#存储来源相关中文
list_title_sources=['检品来源','来源','供样单位','申报单位','被抽样单位','被抽验单位','被抽样单位名称']
#存储检验单位相关中文
list_title_testoffices=['检验单位','检验机构']
#存储检验物质相关中文
list_title_testobjectives=['检验物质']
#存储检验依据相关中文
list_title_regulations=['检验依据']
#存储备注相关中文
list_title_notices=['备注']
#B类,存储列信息
list_name=[]
list_manufacturer=[]
list_pichno=[]
list_specification=[]
list_unpasseditem=[]
list_validperiod=[]
list_reportdate=[]
list_source=[]
list_testoffice=[]
list_testobjective=[]
list_regulation=[]
list_year=[]
list_file=[]
list_url=[]
list_notice=[]
list_fake=[]
#把excel数据转换为列为元素的列表 函数
def List_columns(table,ncols):
for i in range(ncols):
list1=table.col_values(i)
list_columns.append(list1)
return list_columns
#获取list_columnInformation数据
#list_columns是把excel数据转换为列为元素的列表
#list_title存储列标签信息,例如list_title_unpasseditems
#list_columnInformation表示搜索到的相关列信息,例如list_names
def List_columnInformation(list_columns,list_title_names,list_columnInformation):
for i in range(len(list_columns)):
#获取列数据
list_column=list_columns[i]
#title表示标题,例如产品名字
title=list_column[0]
#字段名去除空格
title1=title.replace(" ","")
#print("title:",title)
if title1 in list_title_names:
#print("find title")
list_columnInformation=list_column[1:]
return list_columnInformation
else:
list_columnInformation=['']*(nrows-1)
return list_columnInformation
#用于获取报告时间,网址,文件名等列信息
def List_repeat_columnInformation(nrows,value):
list_repeat_columnInformation=[value]*(nrows-1)
return list_repeat_columnInformation
#获取各列数据
list_columns=List_columns(table,ncols)
list_name=List_columnInformation(list_columns,list_title_names,list_name)
list_manufacturer=List_columnInformation(list_columns,list_title_manufacturers,list_manufacturer)
list_pichno=List_columnInformation(list_columns,list_title_pitchnos,list_pichno)
list_specification=List_columnInformation(list_columns,list_title_specifications,list_specification)
list_unpasseditem=List_columnInformation(list_columns,list_title_unpasseditems,list_unpasseditem)
list_validperiod=List_columnInformation(list_columns,list_title_validperiods,list_validperiod)
list_reportdate=List_repeat_columnInformation(nrows,reportdate)
list_source=List_columnInformation(list_columns,list_title_sources,list_source)
list_testoffice=List_columnInformation(list_columns,list_title_testoffices,list_testoffice)
list_testobjective=List_columnInformation(list_columns,list_title_testobjectives,list_testobjective)
list_regulation=List_columnInformation(list_columns,list_title_regulations,list_regulation)
list_adminadd=List_repeat_columnInformation(nrows,admin)
list_year=List_repeat_columnInformation(nrows,year)
list_file=List_repeat_columnInformation(nrows,file)
list_url=List_repeat_columnInformation(nrows,url)
list_notice=List_columnInformation(list_columns,list_title_notices,list_notice)
list_fake=List_repeat_columnInformation(nrows,'')
#pandas字典写入excel会有标题排序问题,所以用a,b,c等顺序字母代替
data=pd.DataFrame({'a':list_name,'b':list_manufacturer,
'c':list_pichno,'d':list_specification,
'e':list_unpasseditem,'f':list_validperiod,
'g':list_reportdate,'h':list_source,
'i':list_testoffice,
'j':list_testobjective,
'k':list_regulation,'l':list_adminadd,
'm':list_year,'n':list_file,'o':list_url,
'p':list_notice,'q':list_fake})
data.to_excel("ypzl_normal.xlsx")

ypzl药品质量不合格数据库-excel自动排版的更多相关文章
- 大手册(书籍)排版利器-XML自动排版生成工具
--支持全球化/多语言/符合W3C标准的XML自动排版工具 Boxth XML/XSL Formatter是专为XML数据或其他结构化数据源自动输出排版文件(如: PDF等)而设计的集数据格式化.版式 ...
- 自动排版工具——XML自动排版生成工具
——支持全球化/多语言/符合W3C标准的XML自动排版工具 Boxth XML/XSL Formatter是专为XML数据或其他结构化数据源自动输出排版文件(如: PDF等)而设计的集数据格式化.版式 ...
- SQL Server数据库定时自动备份
SQL Server 数据库定时自动备份[转] 在SQL Server中出于数据安全的考虑,所以需要定期的备份数据库.而备份数据库一般又是在凌晨时间基本没有数据库操作的时候进行,所以我们不可能要求 ...
- eclipse自动排版JSP问题
eclipse自动排版JSP非常难看,标签每行显示不完整,开发时很难受,下面设置一下这个就好多了: window-->preferences-->Web-->HTML Files-- ...
- eclipse 自动排版
自动排版: ctrl + i 同名变量高亮: shift+alt+ o 导包: shift+ctrl +o
- Hibernate连接mysql数据库并自动创建表
天才第一步,雀氏纸尿裤,Hibernate第一步,连接数据库. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个 ...
- Windows环境下Oracle数据库的自动备份脚本
批处理文件(.bat) @echo off echo ================================================ echo Windows环境下Oracle数据 ...
- myeclipse自动排版
myeclipse代码排版方式有两种: 1. ctr+f 实现自动排版: 2. myeclipse->Preference->Java->Editor->Sava Action ...
- 使用SQL Server维护计划实现数据库定时自动备份
在SQL Server中出于数据安全的考虑,所以需要定期的备份数据库.而备份数据库一般又是在凌晨时间基本没有数据库操作的时候进行,所以我们不可能要求管理员每天守到晚上1点去备份数据库.要实现数据库的定 ...
随机推荐
- .NET重构(类型码的设计、重构方法)
阅读目录: 1.开篇介绍 2.不影响对象中的逻辑行为(枚举.常量.Entity子类来替代类型码) 3.影响对象中的逻辑行为(抽象出类型码,使用多态解决) 4.无法直接抽象出类型码(使用策略模式解决) ...
- 大数据系列(3)——Hadoop集群完全分布式坏境搭建
前言 上一篇我们讲解了Hadoop单节点的安装,并且已经通过VMware安装了一台CentOS 6.8的Linux系统,咱们本篇的目标就是要配置一个真正的完全分布式的Hadoop集群,闲言少叙,进入本 ...
- SQL Server 2008 R2——统计各部门某年入职人数
=================================版权声明================================= 版权声明:原创文章 谢绝转载 请通过右侧公告中的“联系邮 ...
- 淘宝技术牛p博客整理
淘宝的技术牛人的博客http://blog.csdn.net/zdp072/article/details/19574793
- CentOS 7安装JDK
一.卸载系统自带的openjdk 1.查询系统内置的jdk,使用命令如下: rpm -qa | grep java 此时会列出系统中存在的jdk,如果存在就进行卸载,不存在就直接进行安装. 2.进行卸 ...
- [WPF系列]基础Combox
示例 参考 WPF combobox SelectedValue binding to string Confused with wpf ComboBox DisplayMemberPath, ...
- (转)String、StringBuffer与StringBuilder之间区别
原文地址: http://www.cnblogs.com/A_ming/archive/2010/04/13/1711395.html 关于这三个类在字符串处理中的位置不言而喻,那么他们到底有什么优缺 ...
- springmvc 上传下载
springmvc文件上传下载在网上搜索的代码 参考整理了一份需要使用的jar.commons-fileupload.jar与commons-io-1.4.jar 二个文件 1.表单属性为: enct ...
- UVALive 4428 Solar Eclipse --计算几何,圆相交
题意:平面上有一些半径为R的圆,现在要在满足不与现有圆相交的条件下放入一个圆,求这个圆能放的位置的圆心到原点的最短距离. 解法:我们将半径扩大一倍,R = 2*R,那么在每个圆上或圆外的位置都可以放圆 ...
- C#多维数组与嵌套数组
using System; namespace abc.e.f//等价于下面分层嵌套的写法.且这种写法不管命名空间abc有没有定义过,也不管命名空间e有没有定义过 { class MYTestX { ...