99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀python鏈接oracle數(shù)據(jù)庫以及數(shù)據(jù)庫的增刪改查實(shí)例
python鏈接oracle數(shù)據(jù)庫以及數(shù)據(jù)庫的增刪改查實(shí)例
2018-08-12
收藏

python鏈接oracle數(shù)據(jù)庫以及數(shù)據(jù)庫的增刪改查實(shí)例

初次使用python鏈接oracle,所以想記錄下我遇到的問題,便于向我這樣初次嘗試的朋友能夠快速的配置好環(huán)境進(jìn)入開發(fā)環(huán)節(jié)。

1.首先,python鏈接oracle數(shù)據(jù)庫需要配置好環(huán)境。
我的相關(guān)環(huán)境如下:

1)python:Python 3.6.3 (v3.6.3:2c5fed8, Oct 3 2017, 17:26:49) [MSC v.1900 32 bit (Intel)] on win32

2)oracle:11.2.0.1.0 64bit。這個(gè)是server版本號(hào),在鏈接oracle數(shù)據(jù)庫的時(shí)候還需要oracle的客戶端版,客戶端版本的下載也要參考python的版本,python是32位的客戶端下載也要用32位。

3)cx_Oracle:python鏈接oracle的驅(qū)動(dòng)包,這個(gè)需要自己安裝,https://pypi.python.org/pypi/cx_Oracle/5.3在這個(gè)網(wǎng)址中下載對(duì)應(yīng)的驅(qū)動(dòng),下載驅(qū)動(dòng)的時(shí)候一定要選好對(duì)應(yīng)的版本,我的python是3.6的32位版本,所以在下載驅(qū)動(dòng)的時(shí)候也要選擇對(duì)應(yīng)的版本,我選擇的版本是cx_Oracle-5.3-11g.win32-py3.6.exe (md5),下載后直接安裝運(yùn)行就行了,他會(huì)有一個(gè)自檢,如果沒有通過就說明你的驅(qū)動(dòng)版本沒有下載對(duì)。

2.上面的工作做好之后,在剛才下載好的oracle客戶端版本中找到下面三個(gè)文件:oci.dll、oraocci11.dll、oraociei11.dll,將這幾個(gè)dll文件復(fù)制到

Python\Python36-32\Lib\site-packages文件夾中。

3.在python中輸入:    
import cx_Oracle

沒有報(bào)錯(cuò)的話說明驅(qū)動(dòng)安裝成功。

4.數(shù)據(jù)庫連接操作:    
conn = cx_Oracle.connect('xzt/xzt@localhost/testdb')#這里的順序是用戶名/密碼@oracleserver的ip地址/數(shù)據(jù)庫名字
  cur = conn.cursor()
  sql = "SELECT * FROM DUAL"
  cur.execute(sql)
  cur.close()
  conn.commit()
  conn.close()

5.數(shù)據(jù)庫查詢:    
import cx_Oracle
 
conn = cx_Oracle.connect('xzt/xzt@localhost/testdb')  
cursor = conn.cursor ()
 
cursor.execute ("SELECT * FROM STUDENT_TB")
rows = cursor.fetchall() #得到所有數(shù)據(jù)集
for row in rows:
  print("%d, %s, %s, %s" % (row[0], row[1], row[2], row[3]))#python3以上版本中print()要加括號(hào)用了
 
print("Number of rows returned: %d" % cursor.rowcount)
 
cursor.execute ("SELECT * FROM STUDENT_TB")
while (True):
  row = cursor.fetchone() #逐行得到數(shù)據(jù)集
  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 ()

6.數(shù)據(jù)庫插入:    
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才行,要不然數(shù)據(jù)是不會(huì)插入的
 
cursor.close()
conn.close()

7案例:從某網(wǎng)站上面爬取彩票號(hào)碼    
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
 
    #將查詢到的號(hào)碼入庫
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()#這里一定要提交,要不然是沒有辦法將數(shù)據(jù)入庫的
    conn.close()#記得要關(guān)閉會(huì)話
def Geturl(html):
    reg = r'上一期:<a href="(.*)" rel="external nofollow" 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 = '網(wǎng)站地址'
html1 = getHtml(str1)
RecodeToOracle(getNumber(html1))
Geturl(html1)
上面的代碼用了遞歸運(yùn)算,循環(huán)讀取彩票信息,可以一直讀取到2003年第一期,由于使用的是遞歸,在性能上不是很好,代碼非常吃內(nèi)存,電腦內(nèi)存不夠的朋友就不要嘗試了,容易死機(jī)。

數(shù)據(jù)分析咨詢請(qǐng)掃描二維碼

若不方便掃碼,搜微信號(hào):CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個(gè)參數(shù)驗(yàn)證碼對(duì)象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個(gè)配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺(tái)檢測極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時(shí)表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請(qǐng)參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時(shí)完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請(qǐng)輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請(qǐng)輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }