【Oracle】python调取oracle数据教程

2024-04-29 05:52

本文主要是介绍【Oracle】python调取oracle数据教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

(1)安装python和相关库

1.python的下载和安装

2.python安装cx_Oracle库和pandas库

3.本机安装instantclient 数据库客户端

先安装instantclient

然后设置环境变量

(2)准备好连接Oracle数据库地址等五项信息

(3)用python连接到Oracle数据库

1.测试连接情况

2.获取数据示例代码


(1)安装python和相关库

1.python的下载和安装

这个自行上网搜索。

2.python安装cx_Oracle库和pandas库

打开"命令提示符"

输入pip install pandas安装pandas库

输入pip install cx_Oracle安装cx_Oracle库

3.本机安装instantclient 数据库客户端

先安装instantclient

因为不安装这个后面会报错:cx_Oracle.DatabaseError: DPI-1047: Cannot locate a 64-bit Oracle Client library

下载地址:Oracle Instant Client Downloads

注意下载的版本位数,python是64位的instantclient 就下64位的,python是32位的instantclient 就下32位的

然后选择了Version 12.2.0.1.0,下载了basic和sqlplus压缩包

将两者解压到同一个文件夹oracle下,他们的内容会自己放在一起

解压好了就行,免安装的,可以直接用。记得自己解压的路径位置,做好管理。

然后设置环境变量

变量名:Path

变量值:D:\software\oracle\instantclient_21_9

变量名:ORACLE_HOME

变量值:D:\software\oracle\instantclient_21_9

变量名:TNS_ADMIN

变量值:D:\software\oracle\instantclient_21_9\network\admin

变量名:NLS_LANG

变量值:SIMPLIFIED CHINESE_CHINA.ZHS16GBK

(2)准备好连接Oracle数据库地址等五项信息

  • IP地址
  • 端口
  • 用户名
  • 密码
  • 数据库名

(3)用python连接到Oracle数据库

1.测试连接情况

以下代码简单进行连接操作,看能不能连接上

# test.py
import cx_Oracle
if __name__ == '__main__':# 连接到Oracle数据库,需用户名、密码、ip、端口和数据库名conn = cx_Oracle.connect('用户名', '密码', 'ip地址:端口/数据库名')# conn = cx_Oracle.connect('用户名/密码@ip地址:端口/数据库名')# conn = cx_Oracle.connect('用户名', '密码', #                          cx_Oracle.makedsn('ip地址', '端口', None, '数据库名'))# 创建游标cursor = conn.cursor()print('连接数据库成功!')# 关闭游标和oracle数据库cursor.close()conn.close()

运行结果

2.获取数据示例代码

import cx_Oracle
import pandas as pdif __name__ == '__main__':# 连接到Oracle数据库,需用户名、密码、ip、端口和数据库名conn = cx_Oracle.connect('username', 'password', 'ip:端口/数据库名')# 创建游标cursor = conn.cursor()# 撰写sql语句,需要什么字段就查询什么字段sql = 'select S_INFO_WINDCODE,ANN_DT from AShareANNFinancialIndicator'# 通过游标和sql获取数据test = cursor.execute(sql)# print(test.fetchmany(50)) # 前50行数据data = test.fetchall()  # 全部数据# 获取英文列名title = [i[0] for i in cursor.description]print(title)print(type(title))# 数据处理df = pd.DataFrame(data=data, columns=title)print(data)pass# 关闭游标和oracle数据库cursor.close()conn.close()

end

这篇关于【Oracle】python调取oracle数据教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/945254

相关文章

【深耕 Python】Quantum Computing 量子计算机(5)量子物理概念(二)

写在前面 往期量子计算机博客: 【深耕 Python】Quantum Computing 量子计算机(1)图像绘制基础 【深耕 Python】Quantum Computing 量子计算机(2)绘制电子运动平面波 【深耕 Python】Quantum Computing 量子计算机(3)重要数学公式一览 【深耕 Python】Quantum Computing 量子计算机(4)量子物理概

理解python中的Iterator 和 Iterable 迭代器和可迭代对象

为什么有些对象可以用for … in 循环 我们先看一段代码: list = [1, 2, 3, 4, 5]for i in list:logger.info(i) 这代码定义了1个数组object list, 然后用 for … in 来遍历这个list 看起来合理没什么值得注意 但其实 for … in 后面对象还可以是个String for i in "hello":lo

python中的装饰器,例子说明

在Python中,嵌套装饰器是指在一个函数上应用多个装饰器。每个装饰器都可以为函数添加一些特定的功能。以下是一个稍微复杂一些的例子,我们将创建一个记录日志和验证权限的嵌套装饰器。 ### 例子:记录日志和权限验证的嵌套装饰器 假设我们正在开发一个简单的web应用,并且需要对某些视图函数进行日志记录和权限验证。 #### 1. 日志记录装饰器 首先,我们创建一个用于记录日志的装饰器: ``

python视频转码脚本

今天有一个临时的需求,就是需要将一个wmv的初步转码成mp4的格式。找了一圈,免费的工具少,即使有免费的工具,在功能上也是有所限制,或者会给你塞广告或者附带安装其它流氓小游戏或者杀毒程序。 我并非不支持正版,我本人不是专业的视频创作者,平日里对视频转码编辑的需求极少,为这临时需要而买个正常软件,一没必要,二不划算。 FFmpeg 是一个强大的开源视频工具包,通过命令行可以轻易的将一个 wmv

大数据Scala教程从入门到精通第七篇:Scala在IDEA中编写Hello World

一:Scala在IDEA中编写Hello World         想让我们的idea支持scala的编写,需要安装一个插件。

Python从0到POC编写--模块(二)

RE模块: re 正则表达式模块,这个大家应该都比较熟悉。 语法: re.match(pattern, string, flags=0) 其中: pattern 是匹配的正则表达式 string 是要匹配的字符串。 flags 是标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。 正则表达式: 单字符匹配规则: 字符功能.(点)匹配任意1个字符(除了

sqlite使用之模糊查询数据库数据的三种方式(待完善)

android sqlite使用之模糊查询数据库数据的三种方式 android应用开发中常常需要记录一下数据,而在查询的时候如何实现模糊查询呢?很少有 文章来做这样的介绍,所以这里简单的介绍下三种sqlite的模糊查询方式,直接上代码把: package com.example.utils; import  java.util.ArrayList; import android.

Spring MVC 3学习笔记+教程(三)返回JSON数据

Spring MVC响应中返回JSON数据的方法: 配置与以前相同使用 <mvc:annotation-driven/>的注解配置, 但WEB-INF/lib的类路径里面要有 jackson-all-1.6.9.jar这个库文件, 然后在controller里面这样写: @Controller @RequestMapping

Spring MVC 3学习笔记+教程(二)在controller和视图之间传递参数

Spring MVC3在controller和视图之间传递参数的方法: 一, 从controller往视图传递值, controller---->视图 1)简单类型,如int, String,直接写在controller方法的参数里,是无法传递到视图页面上的(经测试)。 (而用@RequestParam("name")注解,可以从视图上,或地址中加

Spring MVC 3学习笔记+教程(一)开发环境搭建和HelloWorld程序

Spring MVC 3提供了基于注解、REST风格等特性,有些方面比Struts 2方便一些。 这里进行Spring MVC 3的开发环境搭建,即开发Hello World程序。 1,拷贝Spring MVC 3类库到WEB-INF/lib下,经测试至少需要如下几个,版本为Spring 3.1.1: org.springframework.asm-