国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python實現按行切分文本文件的方法

2019-11-25 16:50:25
字體:
來源:轉載
供稿:網友

本文實例講述了python實現按行切分文本文件的方法。分享給大家供大家參考,具體如下:

python腳本利用shell命令來實現文本的操作, 這些命令大大減少了我們的代碼量。

比如按行切分文件并返回切分后得到的文件列表,可以利用內建的split命令進行切分。為了返回得到的文件列表名,可以先將文件切分到自建的子目錄中,然后通過os.listdir獲取所有文件,再將這些文件移到上一級目錄(即函數參數指定的新目錄),刪除自建子目錄,最后返回該文件名列表。

代碼如下,如發現問題歡迎指正:

# 創建新路徑def make_dirs(path):  if not os.path.isdir(path):    os.makedirs(path)# 獲取文件的行數def get_total_lines(file_path):  if not os.path.exists(file_path):    return 0  cmd = 'wc -l %s' % file_path  return int(os.popen(cmd).read().split()[0])# 函數split_file_by_row: 按行切分文件# filepath: 切分的目標文件# new_filepath: 生成新文件的路徑# row_cnt: 每個文件最多包含幾行# suffix_type: 新文件后綴類型,如兩位字母或數字# return: 切分后的文件列表def split_file_by_row(filepath, new_filepath, row_cnt, suffix_type='-d'):  tmp_dir = "/split_file_by_row/"  make_dirs(new_filepath)  make_dirs(new_filepath+tmp_dir)  total_rows = get_total_lines(filepath)  file_cnt = int(math.ceil(total_rows*1.0/row_cnt))    command = "split -l%d -a2 %s %s %s" % (row_cnt, suffix_type, filepath, new_filepath+tmp_dir)    os.system(command)    filelist = os.listdir(new_filepath+tmp_dir)  command = "mv %s/* %s"%(new_filepath+tmp_dir, new_filepath)  os.system(command)  command = "rm -r %s"%(new_filepath+tmp_dir)  os.system(command)  return [new_filepath+fn for fn in filelist]

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對大家Python程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鲜城| 水城县| 苍溪县| 离岛区| 富平县| 伊宁县| 昭通市| 循化| 福海县| 金华市| 文成县| 正安县| 铜陵市| 盐池县| 宣汉县| 定南县| 寿阳县| 图木舒克市| 高台县| 河池市| 肥乡县| 鄱阳县| 烟台市| 南召县| 仁寿县| 建阳市| 霍城县| 平远县| 湟源县| 阳信县| 柘城县| 吉林省| 宝清县| 宜州市| 河北区| 高州市| 革吉县| 静海县| 海原县| 监利县| 舒兰市|