用Python實(shí)現(xiàn)換行符轉(zhuǎn)換的腳本的教程
很簡(jiǎn)單的一個(gè)東西,在'\n'、'\r\n'、'\r'3中換行符之間進(jìn)行轉(zhuǎn)換。
用法
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()的一個(gè)簡(jiǎn)單的練習(xí)??梢杂?,但還相當(dāng)不完善。
#!/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
相關(guān)文章
python實(shí)現(xiàn)切割url得到域名、協(xié)議、主機(jī)名等各個(gè)字段的例子
今天小編就為大家分享一篇python實(shí)現(xiàn)切割url得到域名、協(xié)議、主機(jī)名等各個(gè)字段的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-07-07python出現(xiàn)RuntimeError錯(cuò)誤問題及解決
這篇文章主要介紹了python出現(xiàn)RuntimeError錯(cuò)誤問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Python機(jī)器學(xué)習(xí)庫(kù)sklearn(scikit-learn)的基礎(chǔ)知識(shí)和高級(jí)用法
Scikit-Learn是 Python 最流行的機(jī)器學(xué)習(xí)庫(kù)之一,它提供了各種工具來實(shí)現(xiàn)、評(píng)估和探索各種學(xué)習(xí)算法,用于,各種機(jī)器學(xué)習(xí)任務(wù),在本教程中,我們將介紹 Scikit-Learn 的基礎(chǔ)知識(shí)和一些高級(jí)用法,并提供一些實(shí)例代碼來幫助我們更好地理解2023-07-07numpy刪除單行、刪除單列、刪除多列實(shí)現(xiàn)方式
這篇文章主要介紹了numpy刪除單行、刪除單列、刪除多列實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02Python3按一定數(shù)據(jù)位數(shù)格式處理bin文件的方法
今天小編就為大家分享一篇Python3按一定數(shù)據(jù)位數(shù)格式處理bin文件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-01-01