python实现按行切分文本文件的方法


Posted in Python onApril 18, 2016

本文实例讲述了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 urlopen 使用小示例
Sep 06 Python
python网络编程调用recv函数完整接收数据的三种方法
Mar 31 Python
Python3调用微信企业号API发送文本消息代码示例
Nov 10 Python
Python实现的基于优先等级分配糖果问题算法示例
Apr 25 Python
pytorch: tensor类型的构建与相互转换实例
Jul 26 Python
python实现ID3决策树算法
Aug 29 Python
使用Python实现正态分布、正态分布采样
Nov 20 Python
Python实现线性判别分析(LDA)的MATLAB方式
Dec 09 Python
Django-rest-framework中过滤器的定制实例
Apr 01 Python
django下创建多个app并设置urls方法
Aug 02 Python
AI:如何训练机器学习的模型
Apr 16 Python
python井字棋游戏实现人机对战
Apr 28 Python
Python获取linux主机ip的简单实现方法
Apr 18 #Python
Python实现递归遍历文件夹并删除文件
Apr 18 #Python
Python简单实现TCP包发送十六进制数据的方法
Apr 16 #Python
Python出现segfault错误解决方法
Apr 16 #Python
Python判断值是否在list或set中的性能对比分析
Apr 16 #Python
python中zip()方法应用实例分析
Apr 16 #Python
Python使用logging结合decorator模式实现优化日志输出的方法
Apr 16 #Python
You might like
smarty实例教程
2006/11/19 PHP
php selectradio和checkbox默认选择的实现方法详解
2013/06/29 PHP
PHP创建XML接口示例
2019/07/04 PHP
User Scripts: Video Download by User Scripts
2007/05/14 Javascript
js 回车提交表单两种实现方法
2012/12/31 Javascript
鼠标滑过出现预览的大图提示效果
2014/02/26 Javascript
javascript记录文本框内文字个数检测文字个数变化
2014/10/14 Javascript
jQuery中extend()和fn.extend()方法详解
2015/06/03 Javascript
jQuery实现获取绑定自定义事件元素的方法
2015/12/02 Javascript
jQuery实现指定区域外单击关闭指定层的方法【经典】
2016/06/22 Javascript
详细谈谈javascript的对象
2016/07/31 Javascript
vue.js实现表格合并示例代码
2016/11/30 Javascript
bootstrap模态框跳转到当前模板页面 框消失了而背景存在问题的解决方法
2020/11/30 Javascript
vue2.0路由切换后页面滚动位置不变BUG的解决方法
2018/03/14 Javascript
vue实现简单的星级评分组件源码
2018/11/16 Javascript
Vue 实现把表单form数据 转化成json格式的数据
2019/10/29 Javascript
[00:16]热血竞技场
2019/03/06 DOTA
Python实现的递归神经网络简单示例
2017/08/11 Python
Anaconda下安装mysql-python的包实例
2018/06/11 Python
python递归实现快速排序
2018/08/18 Python
python实现朴素贝叶斯算法
2018/11/19 Python
python 随机打乱 图片和对应的标签方法
2018/12/14 Python
详解python调用cmd命令三种方法
2019/07/08 Python
在python中利用try..except来代替if..else的用法
2019/12/19 Python
解决Tensorboard可视化错误:不显示数据 No scalar data was found
2020/02/15 Python
HTML5 video 事件应用示例
2014/09/11 HTML / CSS
Free People中国官网:波西米亚风格女装服饰
2016/08/30 全球购物
Mybag美国/加拿大:英国奢华包包和名牌手袋网站
2020/02/16 全球购物
linux面试题参考答案(10)
2016/10/26 面试题
中层竞聘演讲稿
2014/01/09 职场文书
三年级小学生评语
2014/04/22 职场文书
母亲节演讲稿
2014/05/27 职场文书
中秋晚会策划方案
2014/06/12 职场文书
师德先进个人事迹材料
2014/12/19 职场文书
2016优秀护士求职自荐信
2016/01/28 职场文书
windows server2012 R2下安装PaddleOCR服务的的详细步骤
2022/09/23 Servers