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表的更多相关文章

  1. vlookup函数基本使用--如何将两个Excel表中的数据匹配;excel表中vlookup函数使用方法将一表引到另一表

    vlookup函数基本使用--如何将两个Excel表中的数据匹配:excel表中vlookup函数使用方法将一表引到另一表 一.将几个学生的籍贯匹配出来‘ 二.使用查找与引用函数 vlookup 三. ...

  2. ListView中的数据表格写入Excel中

    SaveFileDialog sfd = new SaveFileDialog(); sfd.DefaultExt = "xls"; sfd.Filter = "Exce ...

  3. java中的数据导出到Excel表中

    整个项目中导出数据到.Excel的源码 import java.io.BufferedOutputStream; import java.io.FileInputStream; import java ...

  4. Qt中将QTableView中的数据导出为Excel文件

    如果你在做一个报表类的程序,可能将内容导出为Excel文件是一项必须的功能.之前使用MFC的时候我就写过一个类,用于将grid中的数据导出为Excel文件.在使用了QtSql模块后,我很容易的将这个类 ...

  5. WPF-将DataGrid控件中的数据导出到Excel

    原文:WPF-将DataGrid控件中的数据导出到Excel 导出至Excel是非常常见,我们可以用很多类库,例如Aspose.NOPI.Interop,在这里我们使用微软自家的工具.我的WPF绑定的 ...

  6. DataTable to Excel(使用NPOI、EPPlus将数据表中的数据读取到excel格式内存中)

    /// <summary> /// DataTable to Excel(将数据表中的数据读取到excel格式内存中) /// </summary> /// <param ...

  7. 如何使用免费控件将Word表格中的数据导入到Excel中

    我通常使用MS Excel来存储和处理大量数据,但有时候经常会碰到一个问题—我需要的数据存储在word表格中,而不是在Excel中,这样处理起来非常麻烦,尤其是在数据比较庞大的时候, 这时我迫切地需要 ...

  8. c#.net循环将DataGridView中的数据赋值到Excel中,并设置样式

    Microsoft.Office.Interop.Excel.Application excel =                new Microsoft.Office.Interop.Excel ...

  9. phpexcel的写操作将数据库中的数据导入到excel中

    这个版本据说是可以支持excel2007,但是我使用2007编辑的xlsx是无法获得该库的支持.于是乎我就将它转化为2003.感觉支持地很好. 下面介绍一下具体的使用: require_once('. ...

随机推荐

  1. 小米华为vivooppo手机记录隐私证据查询

    1.在拨号界面输入:*#*#4636#*#* 2.在输入代码之后 手机会自动跳转到下面这个页面 就可以查看她到底拿着手机在干嘛 2 输入下面代码可以检测小米手机的各种信息 *#*#64663#*#* 

  2. 面试阿里P6难在哪?(面试难点)

    对于很多没有学历优势的人来说,面试大厂是非常困难的,这对我而言,也是一样,出身于二本,原本以为就三点一线的生活度过一生,直到生活上的变故,才让我有了新的想法和目标,因此我这个二本渣渣也奋斗了起来,竟拿 ...

  3. 下载: www.bitmover.com/lmbench,最新版本3.0-a9

    软件说明: lmbench是个用于评价系统综合性能的多平台开源benchmark,能够测试包括文档读写.内存操作.进程创建销毁开销.网络等性能,测试方法简单.Lmbench是个多平台软件,因此能够对同 ...

  4. 马哥Linux SysAdmin学习笔记(四)

    sed:编辑器 sed:Stream EDitor,行编辑器 用法: sed [option]... 'script' inputfile... script: '地址命令' 常用选项: -n:不输出 ...

  5. Linux_搭建Samba服务(匿名访问)

    [RHEL8]-SMBserver:[RHEL7]-SMBclient !!!测试环境我们首关闭防火墙和selinux(SMBserver和SMBclient都需要) [root@localhost ...

  6. mysql默认值

    1.创建表时添加默认值 语法: <字段名><类型><默认值> 实例: MySQL [wordpress]> create table ly_content(  ...

  7. zabbix监控之概念和安装

    一.为什么要要监控 (1)在需要的时刻,提前提醒我们服务器出问题了: (2)当出问题之后,可以找到问题的根源: (3)检查网站/服务器的可用性 1.监控范畴 硬件监控.系统监控.服务监控.性能监控.日 ...

  8. Lua中的元表与元方法学习总结

    前言 元表对应的英文是metatable,元方法是metamethod.我们都知道,在C++中,两个类是无法直接相加的,但是,如果你重载了"+"符号,就可以进行类的加法运算.在Lu ...

  9. 【转载】java与xml

    原文地址:http://www.lai18.com/content/1198237.html java项目中,xml文件一般都是用来存储一些配置信息一般的编程, 多数用来存储配置信息 . 拿JDBC来 ...

  10. GO语言的JSON01---序列化

    package main import ( "encoding/json" "fmt" ) /* 定义待序列化结构体 属性一定要可见,否则json包无法访问 * ...