28、python3.7(windows)将ORACLE11gR2中的数据取出写入excel表
28.1、下载python的离线扩展模块:
1、windows下python的离线扩展模块下载地址为:
https://www.lfd.uci.edu/~gohlke/pythonlibs/
提示:
可以通过python官方的pypi仓库下载linux或windows相应python版本的离线扩展模块:https://pypi.org/
2、下载连接oracle的python离线扩展模块:
3、下载操作excel表的python离线扩展模块:
28.2、安装下载的python离线扩展模块:
1、以管理员的方式运行cmd,进入windows的dos界面,并进入离线python模块所在的目录。
2、安装:
pip isntall cx_Oracle-7.3.0-cp37-cp37m-win_amd64.whl
pip isntall xlrd-1.2.0-py2.py3-none-any.whl
pip isntall xlutils-2.0.0-py2.py3-none-any.whl
pip isntall xlwt-1.3.0-py2.py3-none-any.whl
28.3、安装Oracle客户端:
1、下载oralce11gR2客户端:
下载地址为:https://www.oracle.com/database/technologies/instant-client/winx64-64-downloads.html
(1)下载的版本如下(亲测该版本适用于oralce11gR2和oracle10g):
(2)解压该文件,我将其放在C:\Program Files (x86)\目录下。
2、添加环境变量:
3、把oracle客户端的安装文件中以".dll"结尾的文件复制到python的安装目录中:
(1)
(2)
28.4、python代码实现:
# -*- coding: utf-8 -*-
import sys
# 读取excel
import xlrd
# 写入excel
import xlwt
# 操作 Excel 文件的实用工具,如复制、分割、筛选等
from xlutils.copy import copy
# oralc模块
import cx_Oracle as oracle
# 时间模块
import datetime
# 连接数据库的url地址
oracle_url = "net/net@172.16.1.88:1521/orcl"
# 输入文件路劲,文件必须存在
file_in_path = "lc.xls"
# 输出文件路径,自动创建文件,如果文件已存在则自动覆盖
file_out_path = "chang.xls"
# excel的sheet表名
sheet_name = "Sheet1"
# 输出显示内容
class Logger(object):
def __init__(self, filename='default.log', stream=sys.stdout):
self.terminal = stream
# 如果没有就新生成一个文件,存在就覆盖
self.log = open(filename, 'w', encoding="utf-8")
def write(self, message):
self.terminal.write(message)
self.log.write(message)
def flush(self):
pass
# 获取当前时间
now_time = datetime.datetime.now().strftime('%Y-%m-%d')
# 将正常日志和错误日志分别写入到两个文件中
sys.stdout = Logger(now_time + '-normal.log', sys.stdout)
sys.stderr = Logger(now_time + '-error.log', sys.stderr)
try:
# 数据库连接
db = oracle.connect(oracle_url)
# 创建cursor
cursor = db.cursor()
# 打开已存在的表
oldWb = xlrd.open_workbook(file_in_path, formatting_info=True)
# 复制
newWb = copy(oldWb)
# 取sheet表
newWs = newWb.get_sheet(sheet_name)
# 执行sql语句
def exec_sql(sql):
return cursor.execute(sql).fetchall()
# 在excel表中插入数据
def insert_excel(row, col, value):
# 写入数据
newWs.write(row, col, value)
# sql语句
sql = "select * from bhl_user"
# 从数据库中取出的数据
value = exec_sql(sql)[0][1]
# 将取出的数据插入到excel表中第几行第几列,表格的坐标是从0开始计算的
insert_excel(2, 4, value)
print("insert into data success!")
except Exception as msg:
print(msg)
print("insert into data faild!")
# 关闭数据库连接
db.close()
# 保存文件
newWb.save(file_out_path)
28、python3.7(windows)将ORACLE11gR2中的数据取出写入excel表的更多相关文章
- vlookup函数基本使用--如何将两个Excel表中的数据匹配;excel表中vlookup函数使用方法将一表引到另一表
vlookup函数基本使用--如何将两个Excel表中的数据匹配:excel表中vlookup函数使用方法将一表引到另一表 一.将几个学生的籍贯匹配出来‘ 二.使用查找与引用函数 vlookup 三. ...
- ListView中的数据表格写入Excel中
SaveFileDialog sfd = new SaveFileDialog(); sfd.DefaultExt = "xls"; sfd.Filter = "Exce ...
- java中的数据导出到Excel表中
整个项目中导出数据到.Excel的源码 import java.io.BufferedOutputStream; import java.io.FileInputStream; import java ...
- Qt中将QTableView中的数据导出为Excel文件
如果你在做一个报表类的程序,可能将内容导出为Excel文件是一项必须的功能.之前使用MFC的时候我就写过一个类,用于将grid中的数据导出为Excel文件.在使用了QtSql模块后,我很容易的将这个类 ...
- WPF-将DataGrid控件中的数据导出到Excel
原文:WPF-将DataGrid控件中的数据导出到Excel 导出至Excel是非常常见,我们可以用很多类库,例如Aspose.NOPI.Interop,在这里我们使用微软自家的工具.我的WPF绑定的 ...
- DataTable to Excel(使用NPOI、EPPlus将数据表中的数据读取到excel格式内存中)
/// <summary> /// DataTable to Excel(将数据表中的数据读取到excel格式内存中) /// </summary> /// <param ...
- 如何使用免费控件将Word表格中的数据导入到Excel中
我通常使用MS Excel来存储和处理大量数据,但有时候经常会碰到一个问题—我需要的数据存储在word表格中,而不是在Excel中,这样处理起来非常麻烦,尤其是在数据比较庞大的时候, 这时我迫切地需要 ...
- c#.net循环将DataGridView中的数据赋值到Excel中,并设置样式
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel ...
- phpexcel的写操作将数据库中的数据导入到excel中
这个版本据说是可以支持excel2007,但是我使用2007编辑的xlsx是无法获得该库的支持.于是乎我就将它转化为2003.感觉支持地很好. 下面介绍一下具体的使用: require_once('. ...
随机推荐
- [Java] 开课吧--JVM
双亲委派 向上委托,向下加载 收到加载任务后,先交给父类加载器,只有当父类加载器无法完成,才会执行加载 保证只有一个类加载器加载,避免重复加载 破坏:JDK 1.2后才使用,JDK 1.1的核心类没 ...
- [DB] Spark Core (3)
高级算子 mapPartitionWithIndex:对RDD中每个分区(有下标)进行操作,通过自己定义的一个函数来处理 def mapPartitionsWithIndex[U](f: (Int, ...
- [刷题] 447 Number of Boomerangs
要求 给出平面上n个点,寻找存在多少点构成的三元组(i j k),使得 i j 两点的距离等于 i k 两点的距离 n 最多为500,所有点坐标范围在[-10000, 10000]之间 示例 [[0, ...
- ARM64平台编译stream、netperf出错解决办法 解决办法:指定编译平台为alpha [root@localhost netperf-2.6.0]# ./configure –build=alpha
ARM64平台编译stream.netperf出错解决办法 http://ilinuxkernel.com/?p=1738 stream编译出错信息: [root@localhost stream]# ...
- Zabbix 常用术语
Zabbix 常用术语 1.主机(host) 一台你想监控的网络设备,用IP或域名表示 2.主机组(host group) 主机的逻辑组;它包含主机和模板.-个主机组里的主机和模板之间并没有任何直接的 ...
- 014.Ansible Playbook Role 及调试
一 role 简介 在ansible中,role是将playbook分割为多个文件的主要机制,大大简化了复杂的playbook的编写,同时已与复用 role各个目录的作用及可用文件 files:存放由 ...
- linux进阶之SVN集中式版本控制系统篇
代码上线--版本控制系统 SVN 集中式版本控制系统 git 分布式版本控制系统 SVN是subversion的缩写,即版本控制系统,是一个开放 ...
- 5.1-5 uname、hostname、dmesg、stat、du
5.1 uname:显示系统信息 uname命令用于显示系统相关信息,比如内核版本号.硬件架构等. -a 显示系统所有相关信息 -v 显示内核版本 -m 显示计算机硬件架构 ...
- jsoup select 选择器(Day_02)
"自己"这个东西是看不见的,撞上一些别的什么,反弹回来,才会了解"自己". 所以,跟很强的东西.可怕的东西.水准很高的东西相碰撞,然后才知道"自己&q ...
- 荷小鱼 x mPaaS | 借助 H5 容器改善 App 白屏、浏览器兼容等问题
随着5G.大数据.人工智能技术的应用,各类传统行业纷纷大力推进数字化转型升级. 而受疫情的影响,教育行业也在大幅加速线上化转型进程,各类在线教育应用也在借助各种力量拓张自己的移动端市场领域. 「荷 ...