欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python操作mysql、excel、pdf的示例

 更新時間:2021年03月29日 14:42:57   作者:JKYEC | Jake  
這篇文章主要介紹了python操作mysql、excel、pdf的示例,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下

一、學(xué)習(xí)如何定義一個對象

代碼:

#!/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方法
# 計算 當(dāng)前值小于1,當(dāng)前值:0
# 計算 1 >= 1: True
# 計算 2 >= 1: True
# 計算 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'錯誤類型:{type(e)}')
  print(f'錯誤內(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ù)計輸出
# sku.xls該文檔有 3 個tab頁
sku_file = xlrd.open_workbook(file_name)
print("{0}該文檔有 {1} 個tab頁".format(file_name, sku_file.nsheets))
print("每個tab頁,頁名分別為: {0}".format(sku_file.sheet_names()))

# 2. 讀取xls文件第1頁
# 預(yù)計輸出
# 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ù)為一個數(shù)組
# 預(yù)計輸出
# [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)修改對應(yīng)的wkhtmltopdf安裝路徑,修改其中一個就行了
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這個東西一定要裝,不然無法生成pdf,會報IO方面的錯誤,小白照做就可以,不需要理解

執(zhí)行結(jié)果

生成的文件長這個樣子

baidu_test.pdf

hello.pdf

以上就是python操作mysql、excel、pdf的示例的詳細內(nèi)容,更多關(guān)于python操作mysql、excel、pdf的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python中的socket實現(xiàn)ftp客戶端和服務(wù)器收發(fā)文件及md5加密文件

    python中的socket實現(xiàn)ftp客戶端和服務(wù)器收發(fā)文件及md5加密文件

    這篇文章主要介紹了python中的socket實現(xiàn)ftp客戶端和服務(wù)器收發(fā)文件及md5加密文件的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • Python命令行參數(shù)定義及需要注意的地方

    Python命令行參數(shù)定義及需要注意的地方

    這篇文章主要介紹了Python命令行參數(shù)定義及需要注意的地方,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下
    2020-11-11
  • Python+Pandas 獲取數(shù)據(jù)庫并加入DataFrame的實例

    Python+Pandas 獲取數(shù)據(jù)庫并加入DataFrame的實例

    今天小編就為大家分享一篇Python+Pandas 獲取數(shù)據(jù)庫并加入DataFrame的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • Python中的基本數(shù)據(jù)類型講解

    Python中的基本數(shù)據(jù)類型講解

    這篇文章介紹了Python中的基本數(shù)據(jù)類型,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • python通過郵件服務(wù)器端口發(fā)送郵件的方法

    python通過郵件服務(wù)器端口發(fā)送郵件的方法

    這篇文章主要介紹了python通過郵件服務(wù)器端口發(fā)送郵件的方法,涉及Python發(fā)送郵件的相關(guān)技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • Pytorch中.detach()與.data的用法小結(jié)

    Pytorch中.detach()與.data的用法小結(jié)

    這篇文章主要介紹了Pytorch中.detach()與.data的用法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • 如何基于python測量代碼運行時間

    如何基于python測量代碼運行時間

    這篇文章主要介紹了如何基于python測量代碼運行時間,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • python實現(xiàn)簡單的俄羅斯方塊

    python實現(xiàn)簡單的俄羅斯方塊

    這篇文章主要為大家詳細介紹了python實現(xiàn)簡單的俄羅斯方塊,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • python實現(xiàn)實時視頻流播放代碼實例

    python實現(xiàn)實時視頻流播放代碼實例

    這篇文章主要介紹了python實現(xiàn)實時視頻流播放代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • 基于Python中Remove函數(shù)的用法討論

    基于Python中Remove函數(shù)的用法討論

    這篇文章主要介紹了基于Python中Remove函數(shù)的用法討論,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12

最新評論