美文网首页GIS
python牛刀小试导入excel数据到Oracle

python牛刀小试导入excel数据到Oracle

作者: 老羽 | 来源:发表于2017-05-17 22:23 被阅读136次

实践了一把python操作excel,以及cx_Oracle操作oracle,并读取excel表格数据到oracle。

开发环境

windows10 python3.5

excel操作练习

# encoding: utf-8

import xlrd

# 设置GBK编码
xlrd.Book.encoding = "gbk"

excelPath = r"C:\Users\think\Desktop\盘锦项目\盘锦三期\视频集成相关\视频导入模板.xls"

#打开Excel文件读取数据
data = xlrd.open_workbook(excelPath)
#获取一个工作表
#table = data.sheets()[0]          
#通过索引顺序获取 
#table = data.sheet_by_index(0) #通过索引顺序获取
table = data.sheet_by_name(u'Sheet1')#通过名称获取
#获取整行和整列的值(数组)   
print(table.row_values(1))
print(table.col_values(1))
#获取行数和列数
nrows = table.nrows
ncols = table.ncols
#循环行列表数据
for i in range(1,nrows ):
    print(table.row_values(i))
 
#单元格
cell_A1 = table.cell(0,0).value
cell_C4 = table.cell(1,2).value 
#使用行列索引
cell_A1 = table.row(0)[0].value 
cell_A2 = table.col(1)[0].value
#简单的写入
row = 0 
col = 0 
# 类型 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
ctype = 1 
value = "单元格的值"
xf = 0 # 扩展的格式化 
table.put_cell(row, col, ctype, value, xf) 
table.cell(0,0)  #单元格的值' 
table.cell(0,0).value #单元格的值'

oracle操作练习

import cx_Oracle

#参数:用户名/密码@监听(server主机:server端口/server名称)
#conn = cx_Oracle.connect("test/root@10.80.17.5:1521/userTest")
#参数为:用户名、密码、监听(server主机:server端口/server名称)
#conn = cx_Oracle.connect("test", "root", "10.80.17.5:1521/userTest")
#参数为:用户名、密码、TSN
conn = cx_Oracle.connect("tyum_um", "DEV_TYUM_UM", "PJDB_215")
#创建cursor
cursor = conn.cursor()
sql = "select * from t_um_ob"
#执行sql语句
cursor.execute(sql)
#获取所有的记录
one = cursor.fetchall()
#一条一条的访问记录
for x in one:
    print(x)   
#关闭cursor
cursor.close()
#关闭连接
conn.close()

读取excel导入到oracle

需求:读取excel数据并更新回oracle,excel表格数据见下图:

excel数据

参考代码如下,做了简单的错误处理:

# encoding: utf-8

import xlrd
import cx_Oracle
import re


####配置项######
# 设置excel GBK编码
xlrd.Book.encoding = "gbk"
#Oracle连接配置:用户名、密码、TSN
conn = cx_Oracle.connect("ty_zhzf", "DEV_TY_ZHZF", "PJDB_215")
cursor = conn.cursor()  
#excel路径
excelPath = r"C:\Users\think\Desktop\盘锦项目\盘锦三期\视频集成相关\宜居乡村视频点位2.0.xlsx"

class Camera(object):
    pass

def getFloatValue(value , default=0.0):    
    if( value == None or len(str(value))==0):
        return default
    else:
        return float(value)

def run():
    #打开Excel文件读取数据
    data = xlrd.open_workbook(excelPath)
    table = data.sheets()[0] 
    #获取行数和列数
    nrows = table.nrows   
    ncols = table.ncols


    sql = """update t_sp_video set c_x=:c_x,c_y=:c_y where c_camera_name =:c_camera_name"""


    colName=""
    cameraFullName=""
    cameraName=""
    lon=0.0
    lat=0.0
    cellRowNum=-1
    lstCameraName=[]
    camera=None
    lstCamera =[]
    lstFails =[]

    #遍历excel表
    if(nrows>0):
        #循环行列表数据,从第1行开始;
        for i in range(0,nrows ):
            
            try:
                colName = table.row_values(i)[0]
                if(colName =="点位名称") :
                    cameraFullName = table.row_values(i)[1]
                    regex = re.search('(?<=[村| 会])[\s|\S]*?(?=[\(|\(])',str(cameraFullName))
                    
                    if(regex == None):
                        #cameraName = cameraFullName[-11:-7]
                        cameraName =""                       
                        print("第 {0} 行解析摄像头名称失败!原文:{1}".format(i+1,str(cameraFullName)))
                        cameraFullName=""
                        continue
                    else :
                        cameraName = regex.group()
                        lstCameraName.append(cameraName)
                        cellRowNum = i+1
                        continue
                if(colName =="纬度") :
                    lat = getFloatValue(table.row_values(i)[1])
                    continue
                if(colName =="经度") :
                    lon = getFloatValue(table.row_values(i)[1])
                    
                if(lat>0 and lon >0 and len(cameraName)>0) :                    
                    camera = Camera()
                    camera.cameraName = cameraName
                    camera.lat=lat
                    camera.lon=lon
                    camera.fullName=cameraFullName
                    camera.cellRowNum=cellRowNum
                    lstCamera.append(camera)                   
            except Exception as ex:
                print("第 {0} 行解析摄像头名称失败!,失败原因:{1}".format(i+1,str(ex)))
            lon=-0.0
            lat=-0.0
        
        
        # #查找重复的
        # duplicates    =   set([x  for x   in  lstCamera   if  lstCameraName.count(x.cameraName)>1]) #count()=>total number of occurrences of x in s
        # for item in duplicates :
        #     print(item)
        for item in lstCamera :
            if(lstCameraName.count(item.cameraName)>1):
                lstCamera.remove(item)
                print("ERROR! 第 {0} 行摄像头名称有重复!原文:{1}".format(item.cellRowNum,item.fullName))
                lstFails.append(item.cellRowNum)
            else :                
                cursor.execute(sql,{
                    'c_x' :  item.lon,
                    'c_y': item.lat,
                    'c_camera_name' : item.cameraName                                  
                    })
                rowCount = cursor.rowcount
                if(rowCount==1):
                    # print("第 {0} 行导入成功!原文:{1} 受影响行数 {2}".format(item.cellRowNum,item.fullName,rowCount))
                    pass
                elif (rowCount >1) :
                    print("ERROR! 第 {0} 行导入有重复!原文:{1} 受影响行数 {2}".format(item.cellRowNum,item.fullName,rowCount))
                    lstFails.append(item.cellRowNum)
                elif (rowCount <=0) :
                    print("第 {0} 行导入失败!原文:{1}".format(item.cellRowNum,item.fullName))
                    lstFails.append(item.cellRowNum)
                    
        conn.commit()
        cursor.close()
        conn.close()  
        print(lstFails)   
        print(len(lstFails))   
        
run()

总体感觉比写强类型开发语言要爽一些,和写JS一样,爽得一B。

相关文章

网友评论

本文标题:python牛刀小试导入excel数据到Oracle

本文链接:https://www.haomeiwen.com/subject/ocjjxxtx.html