Python 板


LINE

獲取數值可以用re.split簡單達成 填入文字本來想要用f-string加上\t間隔來排版 發現國字的全形和數字的半形在同一欄時,很難讓欄位對齊 所以做了一點細部的調整 大致的流程是獲得文本list之後,對需要修改的行位做修改,再全部黏起來('\n'.join)覆寫回去 Before: https://i.imgur.com/CQDMUVN.png After: https://i.imgur.com/z8ZfxIW.png 程式碼: import re #設定文字檔路徑 txt_filepath='path/to/data.txt' #定義動作:在文字行的串列中獲取兩個虛線的行索引 def GetDashlineRowIndexes(line_list): i_dashline_row1=None #第一條虛線的行索引 i_dashline_row2=None #第二條虛線的行索引 #逐行搜尋 for i_row,line_text in enumerate(line_list): #判定有10個以上的虛線字元即為虛線行 if '-'*10 in line_text: if not i_dashline_row1: i_dashline_row1=i_row else: i_dashline_row2=i_row break #若兩條的虛線都有找到 if all([i_dashline_row1,i_dashline_row2]): return i_dashline_row1, i_dashline_row2 #若兩行的虛線有其中一條未找到 else: raise ValueError('文字檔應至少包含兩個虛線行') #定義動作:將單行的數據文字串列輸出為單行等寬欄的字串 def RowDataListToOneLine(row_data_list): #設定固定欄寬 space_len=8 #生成新的單行文字內容 new_line='' for row_data in row_data_list: #計算全形字的數量 num_of_fullwidth_chr=sum(ord(s)>126 for s in row_data) #使用f-string排版,設定向右對齊(根據全形字的數量去教準) new_line+=f'{row_data:>{space_len - num_of_fullwidth_chr}}\t' return new_line #讀取所有txt文字 with open(txt_filepath,'r',encoding='utf-8') as f: text=f.read() #分割每一行內容做成list line_list=text.split('\n') #獲取兩個虛線的行索引值 i_dashline_row1, i_dashline_row2 = GetDashlineRowIndexes(line_list) #處理標題列文字行,先獲取標題列的行索引 i_header_row=i_dashline_row1 - 1 #獲取單行標題列文字並分割為串列 header_line=line_list[i_header_row] row_data_list=re.split(r'\s+',header_line.lstrip()) #將原標題列字串替換為等寬欄的字串 line_list[i_header_row]=RowDataListToOneLine(row_data_list) #處理數據列文字行 for i_row in range(i_dashline_row1+1, i_dashline_row2): #獲取單行的數據文字串列 row_data_list=re.split(r'\s+',line_list[i_row].lstrip()) #取左邊10欄 row_data_list=row_data_list[:10] #取得各項數值 W,X,Y,Z,W_w,X_w,Y_w,Z_w=(float(data) for data in row_data_list[2:]) #計算均重,輸出文字格式:取至兩個小數點並向右對齊(若分母為零則顯示0.00) W_avg=f'{W_w/W:>.2f}' if W else '0.00' X_avg=f'{X_w/X:>.2f}' if X else '0.00' Y_avg=f'{Y_w/Y:>.2f}' if Y else '0.00' Z_avg=f'{Z_w/Z:>.2f}' if Z else '0.00' #將原數據列字串替換為等寬欄的字串 line_list[i_row]=RowDataListToOneLine(row_data_list + [W_avg,X_avg,Y_avg,Z_avg]) #重新組成text內容 new_text='\n'.join(line_list) #覆寫檔案 with open(txt_filepath,'w',encoding='utf-8') as f: f.write(new_text) --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 61.216.6.172 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Python/M.1581057249.A.E3A.html ※ 編輯: papple23g (61.216.6.172 臺灣), 02/07/2020 14:41:13
1F:推 billdarkest: 感謝 覺得比我想像中的還要困難 晚上再慢慢消化吸收 02/07 15:29
2F:→ billdarkest: 謝謝! 02/07 15:29
3F:推 zorogto: 推 基礎範本 02/13 07:37
4F:推 cuteSquirrel: push 02/13 16:49







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:iOS站內搜尋

TOP