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按照多个字符对字符串进行分割的方法
Mar 17 Python
在Python中进行自动化单元测试的教程
Apr 15 Python
Python 闭包的使用方法
Sep 07 Python
使用Python & Flask 实现RESTful Web API的实例
Sep 19 Python
python中is与双等于号“==”的区别示例详解
Nov 21 Python
Python实现全排列的打印
Aug 18 Python
python常用数据重复项处理方法
Nov 22 Python
Python3 A*寻路算法实现方式
Dec 24 Python
Python 写了个新型冠状病毒疫情传播模拟程序
Feb 14 Python
Python如何使用27行代码绘制星星图
Jul 20 Python
Jmeter调用Python脚本实现参数互相传递的实现
Jan 22 Python
pandas按条件筛选数据的实现
Feb 20 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
地球防卫队:陪着奥特曼打小怪兽的人类力量 那些经典队服
2020/03/08 日漫
php session应用实例 登录验证
2009/03/16 PHP
PHP操作数组相关函数
2011/02/03 PHP
一个php短网址的生成代码(仿微博短网址)
2014/05/07 PHP
php实现斐波那契数列的简单写法
2014/07/19 PHP
类似GMAIL的Ajax信息反馈显示
2010/02/16 Javascript
jquery 模拟雅虎首页的点击对话框效果
2010/04/11 Javascript
js性能优化 如何更快速加载你的JavaScript页面
2012/03/17 Javascript
js判断两个日期是否相等的方法
2013/09/10 Javascript
JavaScript中判断两个字符串是否相等的方法
2015/07/07 Javascript
Angular.js中$resource高大上的数据交互详解
2017/07/30 Javascript
使用Vue制作图片轮播组件思路详解
2018/03/21 Javascript
vue+VeeValidate 校验范围实例详解(部分校验,全部校验)
2018/10/19 Javascript
个人小程序接入支付解决方案
2019/05/23 Javascript
Vue 中 a标签上href无法跳转的解决方式
2019/11/12 Javascript
Vue + Scss 动态切换主题颜色实现换肤的示例代码
2020/04/27 Javascript
windows下安装Python和pip终极图文教程
2017/03/05 Python
python中hashlib模块用法示例
2017/10/30 Python
Python中交换两个元素的实现方法
2018/06/29 Python
Windows 64位下python3安装nltk模块
2018/09/19 Python
使用Python检测文章抄袭及去重算法原理解析
2019/06/14 Python
pycharm编写spark程序,导入pyspark包的3中实现方法
2019/08/02 Python
详解使用Python下载文件的几种方法
2019/10/13 Python
Python&&GDAL实现NDVI的计算方式
2020/01/09 Python
pyinstaller 3.6版本通过pip安装失败的解决办法(推荐)
2020/01/18 Python
使用python操作lmdb对数据读取的实例
2020/12/11 Python
详解CSS3选择器的使用方法汇总
2015/11/24 HTML / CSS
关于box-sizing的全面理解
2016/07/28 HTML / CSS
英国高档百货连锁店:John Lewis
2017/11/20 全球购物
优秀毕业生推荐信
2013/11/02 职场文书
医学生自荐信
2013/12/03 职场文书
工程业务员工作职责
2013/12/07 职场文书
中层竞聘演讲稿
2014/01/09 职场文书
2016年感恩教师节校园广播稿
2015/12/18 职场文书
CSS3实现的文字弹出特效
2021/04/16 HTML / CSS
MySql 缓存查询原理与缓存监控和索引监控介绍
2021/07/02 MySQL