excel表數(shù)據(jù)的導(dǎo)入導(dǎo)出

從excel表導(dǎo)入MySQL數(shù)據(jù)庫(kù)

import xlrd
import pymysql


# 寫(xiě)入excel表數(shù)據(jù)
def insert_data():
    data = xlrd.open_workbook("excel/test.xlsx")
    sheet_names = data.sheet_names()
    # print(sheet_names)
    # 連接數(shù)據(jù)庫(kù)
    db = pymysql.connect(host='localhost', user='root', passwd='123456',
                         db='excel', charset='utf8')
    cursor = db.cursor()
    for i in range(len(sheet_names)):
        # 當(dāng)前sheet的名字
        table_name = sheet_names[i]
        # 當(dāng)前的sheet
        now_table = data.sheet_by_index(i)
        # 獲得當(dāng)前sheet的列數(shù)就是屬性數(shù)
        cols_num = now_table.ncols
        # 獲得當(dāng)前表格的行數(shù),就是有多少的數(shù)據(jù)量
        rows_num = now_table.nrows
        attrs = now_table.row_values(0)
        # 判斷表格是否存在
        flag = cursor.execute("show tables like '%s';" % table_name)
        # print(flag)
        # 表存在
        if flag:
            print("-------")
            # 將當(dāng)前的sheet插入到數(shù)據(jù)庫(kù)
            for j in range(1, rows_num):
                row_value = now_table.row_values(j)
                # 處理要插入的數(shù)據(jù),把非字符串的數(shù)據(jù)轉(zhuǎn)換成字符串類型,同時(shí)將字符串變成 sql語(yǔ)句需要的類型
                for k in range(1, len(row_value)):
                    ctype = now_table.cell(j, k).ctype
                    # print('ctype', ctype)
                    # ctype: 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
                    if ctype == 2 and row_value[k] % 1 == 0:
                        tmp = int(row_value[k])
                        row_value[k] = str(tmp)
                    c = row_value[k]
                    row_value[k] = "'" + c + "'"
                # print(row_value)
                sql = "insert into %s(%s) values(%s);" % (table_name, ','.join(attrs[1:]), ','.join(row_value[1:]))
                cursor.execute(sql)
                db.commit()
        else:
            # 為sheet建表
            cursor.execute(f"create table {table_name} (id int primary key auto_increment);")
            db.commit()
            for l in range(1, cols_num):
                cursor.execute(f"alter table {table_name} add column {attrs[l]} varchar(200);")
                db.commit()
            # 將當(dāng)前的sheet插入到數(shù)據(jù)庫(kù)
            for j in range(1, rows_num):
                row_value = now_table.row_values(j)
                # 處理要插入的數(shù)據(jù)呛踊,把非字符串的數(shù)據(jù)轉(zhuǎn)換成字符串類型,同時(shí)將字符串變成 sql語(yǔ)句需要的類型
                for k in range(1, len(row_value)):
                    ctype = now_table.cell(j, k).ctype
                    print('ctype', ctype)
                    # ctype: 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
                    if ctype == 2 and row_value[k] % 1 == 0:
                        tmp = int(row_value[k])
                        row_value[k] = str(tmp)
                    c = row_value[k]
                    row_value[k] = "'" + c + "'"
                sql = "insert into %s(%s) values (%s);" % (table_name, ','.join(attrs[1:]), ','.join(row_value[1:]))
                cursor.execute(sql)
                db.commit()
    db.close()


if __name__ == '__main__':
    insert_data()

從MySQL數(shù)據(jù)庫(kù)寫(xiě)入excel表

import xlwt
import pymysql
import os
import datetime


# 從數(shù)據(jù)庫(kù)讀取數(shù)據(jù)寫(xiě)入excel祟昭,生成xls or xlsx格式文件
def table_export_to_xls(sql):
    table_name = 'sheet1'
    # 連接數(shù)據(jù)庫(kù)
    db = pymysql.connect(host='localhost', user='root', passwd='123456',
                         db='excel', charset='utf8')
    cursor = db.cursor()
    cursor.execute(sql)
    # 重置游標(biāo)位置
    cursor.scroll(0, mode='absolute')
    # 搜取所有的結(jié)果
    results = cursor.fetchall()
    # print(result)
    # 獲取屬性名
    attrs = cursor.description
    print(attrs)

    workbook = xlwt.Workbook()
    sheet1 = workbook.add_sheet(table_name, cell_overwrite_ok=True)
    # 寫(xiě)入表格的屬性值
    for i in range(1, len(attrs)):
        sheet1.write(0, i-1, attrs[i][0])
    # 將數(shù)據(jù)庫(kù)的數(shù)據(jù)導(dǎo)入表格
    row = 1
    col = 0
    for row in range(1, len(results)+1):
        for col in range(0, len(attrs)-1):
            sheet1.write(row, col, results[row-1][col+1])
    # 保存路徑
    now_path = os.path.dirname(__file__)
    print(now_path)
    file_path = os.path.join(now_path, 'excel')
    print(file_path)
    export_time = datetime.datetime.now().strftime('%Y%m%d%H%M%S')
    file_name = 'test-{0}.xlsx'.format(export_time)
    workbook.save(os.path.join(file_path, file_name))

    if os.path.isfile(os.path.join(file_path, file_name)):
        print('數(shù)據(jù)庫(kù)重成功導(dǎo)出數(shù)據(jù)静汤!')
        return {'path': file_path, 'name': file_name}
    else:
        print('導(dǎo)出失斊冈钦!')
        return 'error'


if __name__ == '__main__':
    sql = "select * from sheet1"
    table_export_to_xls(sql)

PostgreSQL可參考:

https://blog.csdn.net/huangmengfeng/article/details/81005505
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末郊丛,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子瞧筛,更是在濱河造成了極大的恐慌厉熟,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驾窟,死亡現(xiàn)場(chǎng)離奇詭異庆猫,居然都是意外死亡认轨,警方通過(guò)查閱死者的電腦和手機(jī)绅络,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人恩急,你說(shuō)我怎么就攤上這事杉畜。” “怎么了衷恭?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵此叠,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我随珠,道長(zhǎng)灭袁,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任窗看,我火速辦了婚禮茸歧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘显沈。我一直安慰自己软瞎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布拉讯。 她就那樣靜靜地躺著涤浇,像睡著了一般。 火紅的嫁衣襯著肌膚如雪魔慷。 梳的紋絲不亂的頭發(fā)上只锭,一...
    開(kāi)封第一講書(shū)人閱讀 51,754評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音院尔,去河邊找鬼纹烹。 笑死,一個(gè)胖子當(dāng)著我的面吹牛召边,可吹牛的內(nèi)容都是我干的铺呵。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼隧熙,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼片挂!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起贞盯,我...
    開(kāi)封第一講書(shū)人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤音念,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后躏敢,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體闷愤,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年件余,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了讥脐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遭居。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖旬渠,靈堂內(nèi)的尸體忽然破棺而出俱萍,到底是詐尸還是另有隱情,我是刑警寧澤告丢,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布枪蘑,位于F島的核電站,受9級(jí)特大地震影響岖免,放射性物質(zhì)發(fā)生泄漏岳颇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一颅湘、第九天 我趴在偏房一處隱蔽的房頂上張望赦役。 院中可真熱鬧,春花似錦栅炒、人聲如沸掂摔。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)乙漓。三九已至,卻和暖如春释移,著一層夾襖步出監(jiān)牢的瞬間叭披,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工玩讳, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留涩蜘,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓熏纯,卻偏偏與公主長(zhǎng)得像同诫,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子樟澜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容