Python 報表自動化

文件管理

序號 方法及描述 描述
1 os.access(path, mode) 檢驗權限模式
2 os.chdir(path) 改變當前工作目錄
3 os.chflags(path, flags) 設置路徑的標記爲數字標記。
4 os.chmod(path, mode) 更改權限
5 os.chown(path, uid, gid) 更改文件所有者
6 os.chroot(path) 改變當前進程的根目錄
7 os.close(fd) 關閉文件描述符 fd
8 os.closerange(fd_low, fd_high) 關閉所有文件描述符,從 fd_low (包含) 到 fd_high (不包含), 錯誤會忽略
9 os.dup(fd) 複製文件描述符 fd
10 os.dup2(fd, fd2) 將一個文件描述符 fd 複製到另一個 fd2
11 os.fchdir(fd) 通過文件描述符改變當前工作目錄
12 os.fchmod(fd, mode) 改變一個文件的訪問權限,該文件由參數fd指定,參數mode是Unix下的文件訪問權限。
13 os.fchown(fd, uid, gid) 修改一個文件的所有權,這個函數修改一個文件的用戶ID和用戶組ID,該文件由文件描述符fd指定。
14 os.fdatasync(fd) 強制將文件寫入磁盤,該文件由文件描述符fd指定,但是不強制更新文件的狀態信息。
15 os.fdopen(fd[, mode[, bufsize]]) 通過文件描述符 fd 創建一個文件對象,並返回這個文件對象
16 os.fpathconf(fd, name) 返回一個打開的文件的系統配置信息。name爲檢索的系統配置的值,它也許是一個定義系統值的字符串,這些名字在很多標準中指定(POSIX.1, Unix 95, Unix 98, 和其它)。
17 os.fstat(fd) 返回文件描述符fd的狀態,像stat()。
18 os.fstatvfs(fd) 返回包含文件描述符fd的文件的文件系統的信息,像 statvfs()
19 os.fsync(fd) 強制將文件描述符爲fd的文件寫入硬盤。
20 os.ftruncate(fd, length) 裁剪文件描述符fd對應的文件, 所以它最大不能超過文件大小。
21 os.getcwd() 返回當前工作目錄
22 os.getcwdu() 返回一個當前工作目錄的Unicode對象
23 os.isatty(fd) 如果文件描述符fd是打開的,同時與tty(-like)設備相連,則返回true, 否則False。
24 os.lchflags(path, flags) 設置路徑的標記爲數字標記,類似 chflags(),但是沒有軟鏈接
25 os.lchmod(path, mode) 修改連接文件權限
26 os.lchown(path, uid, gid) 更改文件所有者,類似 chown,但是不追蹤鏈接。
27 os.link(src, dst) 創建硬鏈接,名爲參數 dst,指向參數 src
28 os.listdir(path) 返回path指定的文件夾包含的文件或文件夾的名字的列表。
29 os.lseek(fd, pos, how) 設置文件描述符 fd當前位置爲pos, how方式修改: SEEK_SET 或者 0 設置從文件開始的計算的pos; SEEK_CUR或者 1 則從當前位置計算; os.SEEK_END或者2則從文件尾部開始. 在unix,Windows中有效
30 os.lstat(path) 像stat(),但是沒有軟鏈接
31 os.major(device) 從原始的設備號中提取設備major號碼 (使用stat中的st_dev或者st_rdev field)。
32 os.makedev(major, minor) 以major和minor設備號組成一個原始設備號
33 os.makedirs(path[, mode]) 遞歸文件夾創建函數。像mkdir(), 但創建的所有intermediate-level文件夾需要包含子文件夾。
34 os.minor(device) 從原始的設備號中提取設備minor號碼 (使用stat中的st_dev或者st_rdev field )。
35 os.mkdir(path[, mode]) 以數字mode的mode創建一個名爲path的文件夾.默認的 mode 是 0777 (八進制)。
36 os.mkfifo(path[, mode]) 創建命名管道,mode 爲數字,默認爲 0666 (八進制)
37 os.mknod(filename[, mode=0600, device]) 創建一個名爲filename文件系統節點(文件,設備特別文件或者命名pipe)。
38 os.open(file, flags[, mode]) 打開一個文件,並且設置需要的打開選項,mode參數是可選的
39 os.openpty() 打開一個新的僞終端對。返回 pty 和 tty的文件描述符。
40 os.pathconf(path, name) 返回相關文件的系統配置信息。
41 os.pipe() 創建一個管道. 返回一對文件描述符(r, w) 分別爲讀和寫
42 os.popen(command[, mode[, bufsize]]) 從一個 command 打開一個管道
43 os.read(fd, n) 從文件描述符 fd 中讀取最多 n 個字節,返回包含讀取字節的字符串,文件描述符 fd對應文件已達到結尾, 返回一個空字符串。
44 os.readlink(path) 返回軟鏈接所指向的文件
45 os.remove(path) 刪除路徑爲path的文件。如果path 是一個文件夾,將拋出OSError; 查看下面的rmdir()刪除一個 directory。
46 os.removedirs(path) 遞歸刪除目錄。
47 os.rename(src, dst) 重命名文件或目錄,從 src 到 dst
48 os.renames(old, new) 遞歸地對目錄進行更名,也可以對文件進行更名。
49 os.rmdir(path) 刪除path指定的空目錄,如果目錄非空,則拋出一個OSError異常。
50 os.stat(path) 獲取path指定的路徑的信息,功能等同於C API中的stat()系統調用。
51 os.stat_float_times([newvalue]) 決定stat_result是否以float對象顯示時間戳
52 os.statvfs(path) 獲取指定路徑的文件系統統計信息
53 os.symlink(src, dst) 創建一個軟鏈接
54 os.tcgetpgrp(fd) 返回與終端fd(一個由os.open()返回的打開的文件描述符)關聯的進程組
55 os.tcsetpgrp(fd, pg) 設置與終端fd(一個由os.open()返回的打開的文件描述符)關聯的進程組爲pg。
56 os.tempnam([dir[, prefix]]) 返回唯一的路徑名用於創建臨時文件。
57 os.tmpfile() 返回一個打開的模式爲(w+b)的文件對象 .這文件對象沒有文件夾入口,沒有文件描述符,將會自動刪除。
58 os.tmpnam() 爲創建一個臨時文件返回一個唯一的路徑
59 os.ttyname(fd) 返回一個字符串,它表示與文件描述符fd 關聯的終端設備。如果fd 沒有與終端設備關聯,則引發一個異常。
60 os.unlink(path) 刪除文件路徑
61 os.utime(path, times) 返回指定的path文件的訪問和修改的時間。
62 os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]]) 輸出在文件夾中的文件名通過在樹中游走,向上或者向下。
63 os.write(fd, str) 寫入字符串到文件描述符 fd中. 返回實際寫入的字符串長度
64 os.path 模塊 獲取文件的屬性信息。

讀取excel

xlrd

import xlrd
workbook = xlrd.open_workbook('excel文件')
#查看錶單名稱
wb.sheet_names()
#得到一個表單
sheet1 = workbook.sheet_by_index(索引號)
sheet1 = workbook.sheet_by_name(/u'名稱')
##獲得表單內容
#按行獲得
for rownum in range(sheet1.nrows):
	print(sheet1.row_values(row_num))
#按列
colval = sheet1.col_values(列索引)

#獲得特定單元格
sheet1.cell(行索引,列索引).value
sheet1.cell(rowx=行索引,colx=列索引).value

#查看單元格數據類型
sheet1.cell(行索引,列索引).ctype

: 讀取表格時,各索引皆是從0開始的

寫excel

xlwt

import xlwt
#創建表
wbk = xlwt.Workbook()
#添加表單
sheet = wbk.add_sheet('sheet 1')
#添加內容
sheet.write(行索引,列索引,內容)
#合併單元格
sheet.write_merge(行始,行終,列始,列終,內容)
wbk.save(保存路徑)

:當更改表單內容時,會有警告提示,這時最好在創建表單時添加參數如下:

sheet2 =  wbk.add_sheet('sheet 2',cell_overwrite_ok=True)
sheet2.write(0,0,'some text')
sheet2.write(0,0,'this should overwrite')

表單格式更改

# 初始化格式
style = xlwt.XFStyle()
 
# 更改格式中的字體
font = xlwt.Font()
font.name = 'Times New Roman'
font.bold = True
style.font = font
 
# 編寫時使用該格式
sheet.write(0, 0, 'some bold Times text', style)

#

修改excel

xlutils
xlutils的橋樑作用

from xlrd import open_workbook
from xlutils.copy import copy
 
rb = open_workbook(文件路徑)
 
#通過sheet_by_index()獲取的sheet沒有write()方法
rs = rb.sheet_by_index(0)
 
wb = copy(rb)
 
#通過get_sheet()獲取的sheet有write()方法
ws = wb.get_sheet(0)
ws.write(0, 0, 'changed!')
 
wb.save('m:\\1.xls')
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章