python操作mysql、excel、pdf的示例
一、學(xué)習(xí)如何定義一個(gè)對(duì)象
代碼:
#!/usr/bin/python # -*- coding: UTF-8 -*- # 1. 定義Person類 class Person: def __init__(self, name, age): self.name = name self.age = age def watch_tv(self): print(f'{self.name} 看電視') # 2. 定義loop函數(shù) # 打印 1-max 中的奇數(shù) def test_person(): person = Person('Jake', 20) print(f'打印person的地址:', person) print(f'person.name:{person.name}') print(f'person.age:{person.age}') person.watch_tv() person = Person('Koko', 18) print(f'打印person的地址:', person) print(f'person.name:{person.name}') print(f'person.age:{person.age}') person.watch_tv() # 3. 執(zhí)行calculate方法 # 計(jì)算 當(dāng)前值小于1,當(dāng)前值:0 # 計(jì)算 1 >= 1: True # 計(jì)算 2 >= 1: True # 計(jì)算 10 >= 1: True test_person()
執(zhí)行結(jié)果:
二、學(xué)習(xí)如何連接MySQL并查詢
代碼塊:
#!/usr/bin/python # -*- coding: UTF-8 -*- # pip3 install pymysql import pymysql from getpass import getpass # from mysql.connector import connect, Error # host = 'xxxxxxx' port = 3306 username = 'db_account_member' password = 'db_account_password' database = 'some_database' def connect_db(): return pymysql.connect(host=host, port=port, user=username, password=password, database=database, charset='utf8') def print_error(e): print(f'錯(cuò)誤類型:{type(e)}') print(f'錯(cuò)誤內(nèi)容:{e}') def close_gracefully(cursor, conn): if cursor: cursor.close() if conn: conn.close() # 查詢數(shù)據(jù)庫,可以寫任意查詢語句 def query(sql): try: conn = connect_db() # 創(chuàng)建連接 cursor = conn.cursor() # 建立游標(biāo) cursor.execute(sql) # 執(zhí)行sql語句 return cursor.fetchall() except pymysql.Error as e: print_error(e) finally: close_gracefully(cursor, conn) query_sql = 'select * from category where id = 1' rows = query(query_sql) print('category表中的數(shù)據(jù)如下:') print(rows)
執(zhí)行結(jié)果:
三、學(xué)習(xí)如何讀寫csv
代碼:
# -*- coding: UTF-8 -*- # 1. 導(dǎo)入csv庫 import csv file_name = '../resources/test.csv' # 2. 定義headers和rows headers = ['index', 'name', 'sex', 'height', 'year'] rows = [ [1, 'Jake', 'male', 177, 20], [2, 'Koko', 'female', 165, 18], [3, 'Mother', 'female', 163, 45], [4, 'Father', 'male', 172, 48] ] # 3. 定義write_csv函數(shù) # 寫入csv def write_csv(): print(f'文件[{file_name}]準(zhǔn)備寫入') with open(f'{file_name}', 'w')as f: f_csv = csv.writer(f) f_csv.writerow(headers) f_csv.writerows(rows) print(f'文件[{file_name}]寫入完畢') # 讀取csv def read_csv(): print(f'文件[{file_name}]準(zhǔn)備讀取') with open(f'{file_name}')as f: f_csv = csv.reader(f) for row in f_csv: print(row) print(f'文件[{file_name}]讀取完畢') # 4. 執(zhí)行write_csv函數(shù) write_csv() print('------') read_csv()
執(zhí)行結(jié)果:
四、讀取xlsx
代碼:
# -*- coding: UTF-8 -*- # 導(dǎo)引 # 安裝相關(guān)依賴 # pip3 install xlrd # 引入xlrd去支持讀取xls相關(guān)的文件 import xlrd # 定義文件名 file_name = '../resources/sku.xls' # 1. 讀取xls文件 # 預(yù)計(jì)輸出 # sku.xls該文檔有 3 個(gè)tab頁 sku_file = xlrd.open_workbook(file_name) print("{0}該文檔有 {1} 個(gè)tab頁".format(file_name, sku_file.nsheets)) print("每個(gè)tab頁,頁名分別為: {0}".format(sku_file.sheet_names())) # 2. 讀取xls文件第1頁 # 預(yù)計(jì)輸出 # tab頁名:Sheet1,該tab頁共有59行,3列 # A6方格的值:1908165140370878 current_sheet_index = 0 # 下標(biāo)0為第一頁tab current_sheet = sku_file.sheet_by_index(current_sheet_index) print("tab頁名:{0},該tab頁共有{1}行,{2}列".format(current_sheet.name, current_sheet.nrows, current_sheet.ncols)) print("A6方格的值:{0}".format(current_sheet.cell_value(rowx=5, colx=0))) # 3. 打印每頁的數(shù)據(jù),每一行的數(shù)據(jù)為一個(gè)數(shù)組 # 預(yù)計(jì)輸出 # [text:'1908154975415329', text:'鞋面是織物 鞋底是聚氨酯底的哦', text:'鞋底是5厘米 內(nèi)增是3厘米 總高度是8厘米左右哦'] # [text:'1908040228021948', text:'鞋面是飛織 鞋底是聚氨酯底的哦', text:'鞋底高度是3厘米左右哦'] # ...以下省略后續(xù)打印 for rx in range(current_sheet.nrows): print(current_sheet.row(rx))
執(zhí)行結(jié)果:
五、讀寫PDF
代碼:
import platform import pdfkit # 這里根據(jù)自己的系統(tǒng)修改對(duì)應(yīng)的wkhtmltopdf安裝路徑,修改其中一個(gè)就行了 win_path = 'D:/tools/wkhtmltopdf' non_win_path = '/usr/local/bin/wkhtmltopdf' def wkhtmltopdf_path(): system = platform.system() if system == 'Darwin': print('蘋果系統(tǒng),可以生成pdf') path = non_win_path elif system == 'Windows': print('Windows系統(tǒng),可以生成pdf') path = win_path elif system == 'Linux系統(tǒng)': print('Linux系統(tǒng),可以生成pdf') path = non_win_path else: print('其他系統(tǒng),暫不支持生成pdf') raise Exception('其他系統(tǒng),暫不支持生成pdf') return path def pre_config(): return pdfkit.configuration(wkhtmltopdf=wkhtmltopdf_path()) # 從鏈接地址生成pdf def generate_pdf_from_url(url, output_file_path): config = pre_config() pdfkit.from_url(url, output_file_path) # 從字符串生成pdf def generate_pdf_from_string(str, output_file_path): config = pre_config() pdfkit.from_string(str, output_file_path) generate_pdf_from_url('https://baidu.com', '../temp/baidu_test.pdf') generate_pdf_from_string('hello', '../temp/hello.pdf')
wkhtmltopdf這個(gè)東西一定要裝,不然無法生成pdf,會(huì)報(bào)IO方面的錯(cuò)誤,小白照做就可以,不需要理解
執(zhí)行結(jié)果
生成的文件長(zhǎng)這個(gè)樣子
baidu_test.pdf
hello.pdf
以上就是python操作mysql、excel、pdf的示例的詳細(xì)內(nèi)容,更多關(guān)于python操作mysql、excel、pdf的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python中的socket實(shí)現(xiàn)ftp客戶端和服務(wù)器收發(fā)文件及md5加密文件
這篇文章主要介紹了python中的socket實(shí)現(xiàn)ftp客戶端和服務(wù)器收發(fā)文件及md5加密文件的相關(guān)知識(shí),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04Python+Pandas 獲取數(shù)據(jù)庫并加入DataFrame的實(shí)例
今天小編就為大家分享一篇Python+Pandas 獲取數(shù)據(jù)庫并加入DataFrame的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-07-07python通過郵件服務(wù)器端口發(fā)送郵件的方法
這篇文章主要介紹了python通過郵件服務(wù)器端口發(fā)送郵件的方法,涉及Python發(fā)送郵件的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04Pytorch中.detach()與.data的用法小結(jié)
這篇文章主要介紹了Pytorch中.detach()與.data的用法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07如何基于python測(cè)量代碼運(yùn)行時(shí)間
這篇文章主要介紹了如何基于python測(cè)量代碼運(yùn)行時(shí)間,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12python實(shí)現(xiàn)簡(jiǎn)單的俄羅斯方塊
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)單的俄羅斯方塊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01python實(shí)現(xiàn)實(shí)時(shí)視頻流播放代碼實(shí)例
這篇文章主要介紹了python實(shí)現(xiàn)實(shí)時(shí)視頻流播放代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01