用Python实现换行符转换的脚本的教程
作者:dbzhang800 发布时间:2021-12-10 23:25:42
标签:Python
很简单的一个东西,在'\n'、'\r\n'、'\r'3中换行符之间进行转换。
用法
usage: eol_convert.py [-h] [-r] [-m {u,p,w,m,d}] [-k] [-f]
filename [filename ...]
Convert Line Ending
positional arguments:
filename file names
optional arguments:
-h, --help show this help message and exit
-r walk through directory
-m {u,p,w,m,d} mode of the line ending
-k keep output file date
-f force conversion of binary files
源码
这只能算是argparse模块和os模块的utime()、stat()、walk()的一个简单的练习。可以用,但还相当不完善。
#!/usr/bin/env python
#2009-2011 dbzhang800
import os
import re
import os.path
def convert_line_endings(temp, mode):
if mode in ['u', 'p']: #unix, posix
temp = temp.replace('\r\n', '\n')
temp = temp.replace('\r', '\n')
elif mode == 'm': #mac (before Mac OS 9)
temp = temp.replace('\r\n', '\r')
temp = temp.replace('\n', '\r')
elif mode == 'w': #windows
temp = re.sub("\r(?!\n)|(?<!\r)\n", "\r\n", temp)
return temp
def convert_file(filename, args):
statinfo = None
with file(filename, 'rb+') as f:
data = f.read()
if '\0' in data and not args.force: #skip binary file... ?
print '%s is a binary file?, skip...' % filename
return
newdata = convert_line_endings(data, args.mode)
if (data != newdata):
statinfo = os.stat(filename) if args.keepdate else None
f.seek(0)
f.write(newdata)
f.truncate()
if statinfo:
os.utime(filename, (statinfo.st_atime, statinfo.st_mtime))
print filename
def walk_dir(d, args):
for root, dirs, files in os.walk(d):
for name in files:
convert_file(os.path.join(root, name), args)
if __name__ == '__main__':
import argparse
import sys
parser = argparse.ArgumentParser(description='Convert Line Ending')
parser.add_argument('filename', nargs='+', help='file names')
parser.add_argument('-r', dest='recursive', action='store_true',
help='walk through directory')
parser.add_argument('-m', dest='mode', default='d', choices='upwmd',
help='mode of the line ending')
parser.add_argument('-k', dest='keepdate', action='store_true',
help='keep output file date')
parser.add_argument('-f', dest='force', action='store_true',
help='force conversion of binary files')
args = parser.parse_args()
if args.mode == 'd':
args.mode = 'w' if sys.platform == 'win32' else 'p'
for filename in args.filename:
if os.path.isdir(filename):
if args.recursive:
walk_dir(filename, args)
else:
print '%s is a directory, skip...' % filename
elif os.path.exists(filename):
convert_file(filename, args)
else:
print '%s does not exist' % filename


猜你喜欢
- 如下所示:加入代码:pd.set_option('display.width', 5000)补充知识:Python 实现不换
- 所需补丁及高版本opatchimage上传后将p6880880_112000_Linux-x86-64.zip解压覆盖$ORACLE_HOM
- SQL Server数据库查询优化的常用方法总结:本文中,abigale代表查询字符串,ada代表数据表名,alice代表字段名。技巧一:问
- 在使用mybatis或者mybatis-plus时候,有些时候会出现数据库的字段名和实体类的字段名不一致的情况,如果运行那么这个字段就会无法
- 前言在上一章中,我们通过基础的搭建,成功的渲染了列表页面.但是,其中的问题是很多的.这一章,我们来解决这些问题.使用 v-bind 绑定数据
- 概述Redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的Web应用程序的完美解决方案。Redis从它的许多竞争继承
- 1.微博三方登录流程1.1 前端获取认证code1.在Vue页面加载时 动态发送请求获取微博授权url2.django收到请求的url后,通
- 本文实例讲述了Python面向对象程序设计之类和对象、实例变量、类变量用法。分享给大家供大家参考,具体如下:类和对象:类的定义:用来描述具有
- auto-vue-fileauto create .vue file by shell command通过终端自动创建vue文件前言:1:
- 写完调用天气接口的demo之后,小程序调用天气接口并且渲染在页面,顺便再调用了一下美图的接口API:美图APIurlwxml:<vie
- 效果图:作用:将页面中的电话号码生成图片格式。<%Public Sub Com_CreatValidCode(pT
- 简介因为javascript默认情况下是单线程的,这意味着代码不能创建新的线程来并行执行。但是对于最开始在浏览器中运行的javascript
- 一、问题的引入opencv在图像处理方面有着非常强大的功能,当我们需要使用opencv进行一些图像的矫正工作时,我们通常需要找到原图的一些关
- Matlab函数对应关系(Numpy)首先给出官网链接,其中详细说明了在Python下如何用Numpy实现Matlab下相同的函数功能。博主
- 环境win10, python3.7,pyinstaller3.6一 下载pyinstaller(1)cmd中pip install pyi
- Vue中有两个较为高级的静态方法mixin和extend,接下来我们来讨论下关于他们各自的原理和使用场景。Mixin:原理:先来看看官网的介
- 我想大家都有一些开了80端口的肉 * ,如果是国内的出于安全就不要往下看了,如果不不妨往下看一下,小弟献丑了,以求抛砖引玉。在肉鸡上放网站最麻
- 上文中,我们一起学习了手把手教你实现一个 Python 计时器。本文中,云朵君将和大家一起了解什么是上下文管理器 和 Python
- 使用递归查找父元素,知道查到想要的元素,然后return getParentTag(startTag) { var self
- vue bus总线的使用场景描述A组件中包括B,C组件,而B组件中包括D组件,这时如果D组件想要在A组件中触发C组件的方法怎么办呢?当然方案