python--连接oracle数据库

文章介绍了如何使用Python的cx_Oracle库连接到Oracle数据库,包括安装cx_Oracle驱动,导入库,执行数据库操作如查询和插入,以及处理DPI-1047错误的方法。同时提供了一个从网站抓取数据并存入数据库的示例。
摘要由CSDN通过智能技术生成

前言

在进行数据库连接之前,一般都需要导入依赖的库,通过专门的库去处理对应的数据库连接,所以没安装对应的处理库的话,需要先进行安装、再导入,导入后即可正常使用。

一、安装cx_Oracle

cx_Oracle:python链接oracle的驱动包,这个需要自己安装,https://pypi.python.org/pypi/cx_Oracle/5.3在这个网址中下载对应的驱动,下载驱动的时候一定要选好对应的版本,我的python是3.6的32位版本,所以在下载驱动的时候也要选择对应的版本,我选择的版本是cx_Oracle-5.3-11g.win32-py3.6.exe (md5),下载后直接安装运行就行了,他会有一个自检,如果没有通过就说明你的驱动版本没有下载对。

在刚才下载好的oracle客户端版本中找到下面三个文件:oci.dll、oraocci11.dll、oraociei11.dll,将这几个dll文件复制到
Python\Python36-32\Lib\site-packages文件夹中。

二、导入库

代码如下(示例):

import cx_Oracle

三、数据库操作实例

3.1 连接

import cx_Oracle
conn = cx_Oracle.connect('xzt/xzt@localhost/testdb')#这里的顺序是用户名/密码@oracleserver的ip地址/数据库名字
cursor = conn.cursor()
print('连接数据库成功!')
sql = "select * from student"
all = cursor.execute(sql)
print(all.fetchall())

3.2数据库查询

import cx_Oracle  
  
conn = cx_Oracle.connect('xzt/xzt@localhost/testdb')    
cursor = conn.cursor ()  
  
cursor.execute ("SELECT * FROM STUDENT_TB")  
rows = cursor.fetchall() #得到所有数据集 
for row in rows:  
    print("%d, %s, %s, %s" % (row[0], row[1], row[2], row[3]))#python3以上版本中print()要加括号用了
  
print("Number of rows returned: %d" % cursor.rowcount)  
  
cursor.execute ("SELECT * FROM STUDENT_TB")  
while (True):  
    row = cursor.fetchone() #逐行得到数据集
    if row == None:  
        break  
    print("%d, %s, %s, %s" % (row[0], row[1], row[2], row[3])) 
      
print("Number of rows returned: %d" % cursor.rowcount)
  
cursor.close ()  
conn.close () 

3.3数据库插入

import cx_Oracle  
  
conn = cx_Oracle.connect('xzp/xzp@localhost/testdb')    
cursor = conn.cursor()  
  
cursor.execute ("CREATE TABLE INSERTTEST(ID INT, C1 VARCHAR(50), C2 VARCHAR(50), C3 VARCHAR(50))")  
  
cursor.execute ("INSERT INTO INSERTTEST (ID, COL1, COL2, COL3)VALUES(1213412, 'asdfa', 'ewewe', 'sfjgsfg')")  
cursor.execute ("INSERT INTO INSERTTEST (ID, COL1, COL2, COL3)VALUES(12341, 'ashdfh', 'shhsdfh', 'sghs')")  
cursor.execute ("INSERT INTO INSERTTEST (ID, COL1, COL2, COL3)VALUES(123451235, 'werwerw', 'asdfaf', 'awew')")  
conn.commit() #这里一定要commit才行,要不然数据是不会插入的 
  
cursor.close()  
conn.close()

3.4 实例从某网站上面爬取彩票号码

import re
import urllib
import cx_Oracle
import urllib.request
 
def getHtml(url):
	page = urllib.request.urlopen(url)
	html= page.read()
	return html
def getNumber(html):
	reg = r'<li class="ball_red">(\d{2})</li>'
	reg2 = r'<li class="ball_blue">(\d{2})</li>'
	regqnumber = r'第 <font class="cfont2"><strong>(\d*)</strong></font>'
	number = re.compile(reg)
	numberblue = re.compile(reg2)
	qnumber = re.compile(regqnumber)
	numberlist = re.findall(number,html.decode('gbk'))
	numberblue = re.findall(numberblue,html.decode('gbk'))
	qnum = re.findall(qnumber,html.decode('gbk'))
	for number in numberblue:
		numberlist.append(number)
	for n in qnum:
		numberlist.append(n)
	print(numberlist)
	return numberlist
 
	#将查询到的号码入库
def RecodeToOracle(list):
	conn = cx_Oracle.connect('xzp/xzp@localhost/testdb.domain')
	cur = conn.cursor()
	sql = "INSERT INTO SSQ (REDNUM1,REDNUM2,REDNUM3,REDNUM4,REDNUM5,REDNUM6,BLUENUM,QNUMBER) VALUES ('%s','%s','%s','%s','%s','%s','%s','%s')"%(list[0],list[1],list[2],list[3],list[4],list[5],list[6],list[7])
	cur.execute(sql)
	cur.close()
	conn.commit()#这里一定要提交,要不然是没有办法将数据入库的
	conn.close()#记得要关闭会话
def Geturl(html):
	reg = r'上一期:<a href="(.*)" target="_blank">'
	url = re.compile(reg)
	urllist = re.findall(url,html.decode('gbk'))
	if len(urllist)!=0:
		print(urllist[0])
		if urllist[0].index('http:')<0:
			urllist[0]='http:'+urllist[0]
		htmlbefore = getHtml(urllist[0])
		# print(htmlbefore)
		numberlist = getNumber(htmlbefore)
		print(len(numberlist))
		RecodeToOracle(numberlist)
		print(numberlist)
		Geturl(htmlbefore)
	else:	
		return
 
str1 = '网站地址'
html1 = getHtml(str1)
RecodeToOracle(getNumber(html1))
Geturl(html1)

四、异常

4.1、运行时,出现连接数据库失败:DatabaseError:DPI-1047

在这里插入图片描述

解决连接失败问题

1、查看Oracle的版本号

#linux下查询
sqlplus / as sysdba
select * from v$version;

在这里插入图片描述

2、进入官网,下载对应Oracle版本

https://www.oracle.com/database/technologies/instant-client/winx64-64-downloads.html
在这里插入图片描述
将下载的包解压,添加到环境变量

3.下载cx_Oracle包:https://www.lfd.uci.edu/~gohlke/pythonlibs/#pyhook

ctrl+f 搜索:cx_Oracle,进入选择匹配python版本的包
这里我的python版本是3.6 64位
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
cmd进入下载cx_Oracle-8.1.0-cp36-cp36m-win_amd64.whl的目录,以下是我本地目录,应修改成你自己的下载目录安装最新下载的包

pip install cx_Oracle-8.1.0-cp36-cp36m-win_amd64.whl

在这里插入图片描述
打开oracle版本的解压包,进入解压后的目录,C:\work\instantclient-basic-windows.x64-12.2.0.1.0\instantclient_12_2(换成你本地的目录,这里是我本地的),把所有的.dll文件全部拷贝到python的根目录
在这里插入图片描述
拷贝到目录如下
在这里插入图片描述

4.在使用python连接时,需要注意以下点:

1、需要下载已安装的oracle数据库对应的版本
2、需要下载与python版本对应的cx_Oracle包
3、需要把oracle版本的ddl文件放置python安装根目录下

### 回答1: 在Matlab中对三维数据进行归一化可以通过以下步骤实现。首先,将三维数据转换为矩阵形式。可以使用Matlab中的reshape函数将三维数据矩阵化。接下来,计算每个维度的最小值和最大值。可以使用Matlab中的min和max函数计算每个维度的最小值和最大值。然后,使用公式将每个维度的数值映射到[0,1]的范围内。公式为 X_norm = (X - min(X)) / (max(X) - min(X)) 其中X表示原始的三维数据,X_norm表示经过归一化之后的数据。最后,将矩阵形式的归一化后的数据重新转换为三维数据形式。可以使用Matlab中的reshape函数将矩阵转换成三维数据形式。这样就完成了对三维数据的归一化。值得注意的是,归一化后的数据更有利于后续数据处理和分析,但是需要注意不要过度归一化,以免损失数据的信息。 ### 回答2: 三维数据的归一化实际上是将三维数组中的数据转换为0到1的范围内。这种转换对于许多机器学习算法来说非常有用,因为它可以提高算法的性能和准确性。 在matlab中实现三维数据的归一化可以使用matlab内置的函数进行操作。具体的操作步骤如下: 1. 将三维数组数据reshape为二维数组 2. 使用matlab内置的min和max函数计算出所有数据的最小值和最大值 3. 对数据进行归一化,具体的计算公式为: normalized_data = (data - min_value) / (max_value - min_value) 其中,data为原始的三维数据数组,min_value为计算出的最小值,max_value为计算出的最大值,normalized_data为归一化后的数据数组。 4. 将归一化后的数据reshape为原始的三维数据数组格式 通过以上步骤,就可以在matlab中实现三维数据的归一化操作了。需要注意的是,在该操作过程中,数据的最小值和最大值是关键的参数,需要根据具体的数据进行计算。 ### 回答3: 对三维数据的归一化是指将三维数据中各个数据之间的差异统一化,使其在同一尺度下进行比较。Matlab提供了多种方式来完成三维数据的归一化,以下是其中两种常用的方式: 1. 使用normalize函数归一化三维数据 normalize函数可以将一个矩阵按列向量归一化,也可以将一个三维矩阵按照第三个维度进行归一化。考虑一个形状为m*n*p的三维矩阵data,其中第三个维度表示样本个数,可以通过以下方式进行归一化: ```matlab normalized_data = normalize(data, 3); ``` 2. 使用zscore函数归一化三维数据 zscore函数可以将一个矩阵按列向量进行标准化,也可以将一个三维矩阵按照第三个维度进行标准化。标准化是一种归一化方式,通过将数据的均值设为0,标准差设为1,来统一数据的尺度。考虑一个形状为m*n*p的三维矩阵data,其中第三个维度表示样本个数,可以通过以下方式进行标准化: ```matlab normalized_data = zscore(data, 0, 3); ``` 上述代码中,第二个参数0表示不将样本个数p减去1进行无偏估计,第三个参数3表示按照第三个维度进行标准化。 通过使用上述两种方式,可以方便地对三维数据进行归一化,从而更好地进行分析和处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值