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

python 操作excel表格的方法

 更新時間:2020年12月05日 11:33:47   作者:小豹子的網絡記事本  
這篇文章主要介紹了python 操作excel表格的方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下

說明:由于公司oa暫缺,人事妹子在做考勤的時候,需要通過幾個excel表格去交叉比對員工是否有曠工或遲到,工作量大而且容易出錯。
這時候it屌絲的機會來啦,花了一天時間給妹子擼了一個自動化腳本。

1. 下載相關python包
python操作excel表格可以使用以下三個包
xlrd - 讀excel文件
xlwt - 寫excel文件,這個不能修改已有的excel文件,只能寫新的文件
xlutils - 修改excel文件,其實就是通過xlrd拷貝一份記錄,再進行修改。保存為老的名字就替換了原文件,保存為新的名字就創(chuàng)建一個新文件

注意事項:
a. python讀取excel的日期和時間時
表格內容是2019/5/13,python讀到的值是43606.0,該值為從日期減1899/12/30得到的天數(shù)
表格內容是9:00:00,python讀到的值是0.375,該值為時間過了一天的比例,即9/24
表格內容是2019/5/13  9:00:00,python讀到的值是43598.375
日期和時間可以直接相加,因為python讀到的都是轉化為數(shù)字之后的值

b. python讀取excel的數(shù)字時,如員工編號為181129,最后結果是181129.0,非整數(shù)

c. 調用save函數(shù)保存新的excel文件時,后綴名必須是.xls

2. 將python文件轉為.bat格式
你不可能要求妹子去使用cmd,然后使用python xx.py去執(zhí)行python文件,必須想個辦法搞成傻瓜式的。我們可以通過.bat格式文件實現(xiàn)
新建文本文件,重命名為“A考勤小工具.bat”,輸入下面代碼,@py.exe表示后面的參數(shù)是python可執(zhí)行文件
@py.exe Akqfx.py

3. 附上相關代碼和excel格式文本

Akqfx.py

# 該腳本為修正考勤記錄
# author: yangbao

import os
from datetime import datetime
import xlrd
from xlutils.copy import copy


# 定義文件是否存在
def get_list_file():
  current_list = os.listdir()
  must_list = ['原始數(shù)據(jù).xls', '外出.xls', '法定假日.xls', '請假.xls']
  cj_set = set(must_list) - set(current_list)
  if cj_set:
    for i in cj_set:
      print('{} 不存在,請檢查!'.format(i))
      return 0
  else:
    return 1


# 定義是否存在流程
def get_qjorwc(file_name, person_id, input_time):
  book = xlrd.open_workbook(file_name)
  book_sheet = book.sheet_by_index(0)
  flag = 0
  for i in range(1, book_sheet.nrows):
    if int(book_sheet.cell_value(i, 1)) == int(person_id):
      # 文件不同,時間處理不同
      if file_name == '請假.xls':
        cell_begin = book_sheet.cell_value(i, 4)
        cell_end = book_sheet.cell_value(i, 5)
      else:
        cell_begin = book_sheet.cell_value(i, 3) + book_sheet.cell_value(i, 4)
        cell_end = book_sheet.cell_value(i, 5) + book_sheet.cell_value(i, 6)
      # 判斷原始數(shù)據(jù)曠工和遲到是否在請假或外出流程里
      # 給額外5min的寬限時間
      if cell_begin-5/1440 <= input_time <= cell_end+5/1440:
        flag = 1
        break
  return flag


# 定義是否是法定假日
def get_fdjr(input_time):
  book = xlrd.open_workbook('法定假日.xls')
  book_sheet = book.sheet_by_index(0)
  flag = 0
  for i in range(1, book_sheet.nrows):
    dt = datetime(*xlrd.xldate_as_tuple(book_sheet.cell_value(i, 0), 0))
    if dt.strftime('%Y-%m-%d') == input_time:
      flag = 1
      break
  return flag


def main():
  ys_book = xlrd.open_workbook('原始數(shù)據(jù).xls')
  ys_book_sheet = ys_book.sheet_by_index(0)
  new_ys_book = copy(ys_book)
  new_ys_book_sheet = new_ys_book.get_sheet(0)
  unnormal_list = ['曠工', '遲到']
  for i in range(ys_book_sheet.nrows):
    # 查上班時間
    if ys_book_sheet.cell_value(i, 5) in unnormal_list:
      # 查是否是法定假日
      dt = ys_book_sheet.cell_value(i, 3)[:10]
      if get_fdjr(dt):
        new_ys_book_sheet.write(i, 5, '*')

      # 查是否有流程
      if ys_book_sheet.cell_value(i, 4) != '':
        cell_on_time = ys_book_sheet.cell_value(i, 3)[:10] + ' ' + ys_book_sheet.cell_value(i, 4)
        cell_on_time_format = datetime.strptime(cell_on_time, "%Y-%m-%d %H:%M:%S") \
                   - datetime.strptime('1899-12-30', '%Y-%m-%d')
        cell_on_time_number = cell_on_time_format.days + cell_on_time_format.seconds / (24 * 3600)
        if 12 < cell_on_time_format.seconds / 3600 < 13:
          cell_on_time_number = cell_on_time_format.days + 11.5/24
      else:
        cell_on_time = ys_book_sheet.cell_value(i, 3)[:10]
        cell_on_time_format = datetime.strptime(cell_on_time, "%Y-%m-%d") \
                   - datetime.strptime('1899-12-30', '%Y-%m-%d')
        cell_on_time_number = cell_on_time_format.days + cell_on_time_format.seconds / (24 * 3600) + 9/24

      qj_on_flag = get_qjorwc('請假.xls', ys_book_sheet.cell_value(i, 1), cell_on_time_number)
      wc_on_flag = get_qjorwc('外出.xls', ys_book_sheet.cell_value(i, 1), cell_on_time_number)
      if qj_on_flag == 1 or wc_on_flag == 1:
        new_ys_book_sheet.write(i, 5, '已有流程')
        new_ys_book_sheet.write(i, 11, '')

    # 查下班時間
    if ys_book_sheet.cell_value(i, 7) in unnormal_list:
      # 查是否是法定假日
      dt = ys_book_sheet.cell_value(i, 3)[:10]
      if get_fdjr(dt):
        new_ys_book_sheet.write(i, 7, '*')
        new_ys_book_sheet.write(i, 11, '')

      # 查是否有流程
      if ys_book_sheet.cell_value(i, 6) != '':
        cell_out_time = ys_book_sheet.cell_value(i, 3)[:10] + ' ' + ys_book_sheet.cell_value(i, 6)
        cell_out_time_format = datetime.strptime(cell_out_time, "%Y-%m-%d %H:%M:%S") \
                    - datetime.strptime('1899-12-30', '%Y-%m-%d')
        cell_out_time_number = cell_out_time_format.days + cell_out_time_format.seconds / (24 * 3600)

        if 12 < cell_out_time_format.seconds / 3600 < 13:
          cell_out_time_number = cell_out_time_format.days + 13.5/24

      else:
        cell_out_time = ys_book_sheet.cell_value(i, 3)[:10]
        cell_out_time_format = datetime.strptime(cell_out_time, "%Y-%m-%d") \
                    - datetime.strptime('1899-12-30', '%Y-%m-%d')
        cell_out_time_number = cell_out_time_format.days + cell_out_time_format.seconds / (24 * 3600) + 18/24

      qj_out_flag = get_qjorwc('請假.xls', ys_book_sheet.cell_value(i, 1), cell_out_time_number)
      wc_out_flag = get_qjorwc('外出.xls', ys_book_sheet.cell_value(i, 1), cell_out_time_number)
      if qj_out_flag == 1 or wc_out_flag == 1:
        new_ys_book_sheet.write(i, 7, '已有流程')
        new_ys_book_sheet.write(i, 11, '')

  new_excel_name = datetime.now().strftime('%Y%m%d_%H%M%S')+'校正后.xls'
  new_ys_book.save(new_excel_name)


if __name__ == '__main__':
  if get_list_file():
    print('開始考勤分析...')
    main()
    print('考勤分析結束...')
    input('按任意鍵結束')
  else:
    input('因為缺少相關excel文件,考勤分析失敗,退出程序,按任意鍵結束')

該文檔僅作個人記錄用

以上就是python 操作excel表格的方法的詳細內容,更多關于python 操作excel表格的資料請關注腳本之家其它相關文章!

相關文章

  • Python使用Srapy框架爬蟲模擬登陸并抓取知乎內容

    Python使用Srapy框架爬蟲模擬登陸并抓取知乎內容

    這里我們來看如何通過Python使用Srapy框架爬蟲模擬登陸并抓取知乎內容的實例,要實現(xiàn)持續(xù)的爬取需要利用到cookie的保存,我們首先還是來回顧一下cookie的相關知識點:
    2016-07-07
  • PyQt5下拉式復選框QComboCheckBox的實例

    PyQt5下拉式復選框QComboCheckBox的實例

    今天小編就為大家分享一篇PyQt5下拉式復選框QComboCheckBox的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python基礎之函數(shù)用法實例詳解

    Python基礎之函數(shù)用法實例詳解

    這篇文章主要介紹了Python中函數(shù)用法,包括了函數(shù)的創(chuàng)建、定義、參數(shù)等,需要的朋友可以參考下
    2014-09-09
  • zip在python中的用法小結

    zip在python中的用法小結

    Python中的zip函數(shù)是一個非常有用的工具,可以幫助我們同時處理多個可迭代對象,通過使用zip函數(shù),我們可以將多個列表或迭代器中的元素打包成一個個元組,然后返回由這些元組組成的列表,這篇文章介紹zip在python中的用法,感興趣的朋友一起看看吧
    2024-02-02
  • python共軛梯度法特征值迭代次數(shù)討論

    python共軛梯度法特征值迭代次數(shù)討論

    這篇文章主要介紹了python共軛梯度法特征值迭代次數(shù)討論,想了解共軛梯度法的同學,需要著重看一下
    2021-04-04
  • Python button選取本地圖片并顯示的實例

    Python button選取本地圖片并顯示的實例

    今天小編就為大家分享一篇Python button選取本地圖片并顯示的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python中BeautifulSoup通過查找Id獲取元素信息

    Python中BeautifulSoup通過查找Id獲取元素信息

    這篇文章主要介紹了Python中BeautifulSoup通過查找Id獲取元素信息,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • Python 3中print函數(shù)的使用方法總結

    Python 3中print函數(shù)的使用方法總結

    這篇文章主要給大家總結介紹了關于Python 3中print函數(shù)的使用方法,python3中的print函數(shù)和之前版本的用法相差很多,本文通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-08-08
  • Python實現(xiàn)股市信息下載的方法

    Python實現(xiàn)股市信息下載的方法

    這篇文章主要介紹了Python實現(xiàn)股市信息下載的方法,涉及Python使用urllib模塊進行URL及文件的相關操作技巧,需要的朋友可以參考下
    2015-06-06
  • Python面向對象程序設計示例小結

    Python面向對象程序設計示例小結

    這篇文章主要介紹了Python面向對象程序設計,結合實例形式總結分析了Python面向對象程序設計中比較常見的類定義、實例化、繼承、私有變量等相關使用技巧與操作注意事項,需要的朋友可以參考下
    2019-01-01

最新評論