Python

sub(pattern, repl, string, count)

第一个参数:规则

第二个参数:替换后的字符串

第三个参数:字符串

第四个参数:替换个数。默认为0,表示每个匹配项都替换

 

re.sub("^\s*|\s*$","",字符串)两端
re.sub("^\s*","",字符串)首
re.sub("\s*$","",字符串)尾

 

# 遍历文件夹下面的所有文件及文件夹,如果是文件,则...如果是文件夹,则...
for i in os.listdir(path):
if os.path.isfile(os.path.join(path,i)):
print(os.path.join(path,i),"文件")
elif os.path.isdir(os.path.join( path,i)):
print(os.path.join(path,i),"文件夹")

目录子孙操作:

# os.path.exists()方法可以直接判断文件/文件夹是否存在

# os.path.isfile("test-data") 判断 test-data 是否文件
# os.path.isdir("hello") 判断 hello是否文件夹
# join:字符串拼接
# os.path.join() 路径拼接
os.mkdir("文件夹名称") 创建文件夹"文件夹名称"可以是绝对路径,也可以是相对路径

os.path.splitext(path)  分割路径,返回路径名和文件扩展名的元组

shutil.rmtree('E:\\myPython\\image-filter\\test', ignore_errors=True)删除E:\\myPython\\image-filter\\test下的所有文件目录及文件夹,并忽略错误
os.path.split(path): #把path分为目录和文件两个部分,以列表返回

os.path.sep:#路径分隔符(由于在Windows和Linux、Mac下路径分隔用的不同的符号,windows下用,linux用/。所以为了写的代码能在多系统上使用,我们尽量不要直接指定\或者/来链接路径。

os.getcwd()返回当前工作目录
os.chdir()切换当前工作目录
os.path.abspath(path)获取文件的绝对路径



open("he.txt","w")创建一个文件
合法mode:r、rb、r+、rb+、w、wb、w+、wb+、a、ab、a+、ab+

read([size])方法从文件当前位置起读取size个字节,若无参数size,则表示读取至文件结束为止,它范围为字符串对象

f = open("a.txt")
lines = f.read()
print lines
print(type(lines))
f.close()

输出
Hello
Welcome
What is the fuck...
<type 'str'> #字符串类型

  

readline()方法,从字面意思可以看出,该方法每次读出一行内容,所以,读取时占用内存小,比较适合大文件,该方法返回一个字符串对象。

f = open("a.txt")
line = f.readline()
print(type(line))
while line:
 print line,
 line = f.readline()
f.close()
输出
<type 'str'>
Hello
Welcome
What is the fuck...

readlines()方法读取整个文件所有行,保存在一个列表(list)变量中,每行作为一个元素,但读取大文件会比较占内存

f = open("a.txt")
lines = f.readlines()
print(type(lines))
for line in lines:
 print line,
f.close()

输出
<type 'list'>
2 Hello
3 Welcome
4 What is the fuck...

 

linecache模块

当然,有特殊需求还可以用linecache模块,比如你要输出某个文件的第n行:

# 输出第2行
text = linecache.getline(‘a.txt',2)
print text,

  


.closed()        判断文件是否关闭
.close() 关闭文件


用法:
for path in os.listdir(path):
print(os.path.abspath(path))


.strip()去除两边空白字符
.lstrip()左边字符
.rstrip()右边









捕捉异常
try:
  代码...
except (异常一,异常二):
  代码...
finally :
  一定执行该代码

  





自定义异常
a = "t"
if a=="t":
    raise  SystemError("刚刚好") //SystemError可以是其他系统内置错误警告,"刚刚好"可以是其他错误自定义提示

  

 
 
BaseException所有异常的基类
SystemExit解释器请求退出
KeyboardInterrupt用户中断执行(通常是输入^C)
Exception常规错误的基类
StopIteration迭代器没有更多的值
GeneratorExit生成器(generator)发生异常来通知退出
StandardError所有的内建标准异常的基类
ArithmeticError所有数值计算错误的基类
FloatingPointError浮点计算错误
OverflowError数值运算超出最大限制
ZeroDivisionError除(或取模)零 (所有数据类型)
AssertionError断言语句失败
AttributeError对象没有这个属性
EOFError没有内建输入,到达EOF 标记
EnvironmentError操作系统错误的基类
IOError输入/输出操作失败
OSError操作系统错误
WindowsError系统调用失败
ImportError导入模块/对象失败
LookupError无效数据查询的基类
IndexError序列中没有此索引(index)
KeyError映射中没有这个键
MemoryError内存溢出错误(对于Python 解释器不是致命的)
NameError未声明/初始化对象 (没有属性)
UnboundLocalError访问未初始化的本地变量
ReferenceError弱引用(Weak reference)试图访问已经垃圾回收了的对象
RuntimeError一般的运行时错误
NotImplementedError尚未实现的方法
SyntaxErrorPython 语法错误
IndentationError缩进错误
TabErrorTab 和空格混用
SystemError一般的解释器系统错误
TypeError对类型无效的操作
ValueError传入无效的参数
UnicodeErrorUnicode 相关的错误
UnicodeDecodeErrorUnicode 解码时的错误
UnicodeEncodeErrorUnicode 编码时错误
UnicodeTranslateErrorUnicode 转换时错误
Warning警告的基类
DeprecationWarning关于被弃用的特征的警告
FutureWarning关于构造将来语义会有改变的警告
OverflowWarning旧的关于自动提升为长整型(long)的警告
PendingDeprecationWarning关于特性将会被废弃的警告
RuntimeWarning可疑的运行时行为(runtime behavior)的警告
SyntaxWarning可疑的语法的警告
UserWarning用户代码生成的警告




打印捕捉异常:
import traceback
traceback.print_exc() 
print(traceback.print_exc()) 打印异常(其实traceback.print_exc()函数只是traceback.print_exception()函数的一个简写形式,而它们获取异常相关的数据都是通过sys.exc_info()函数得到的)
 
 
traceback.print_exc()由下面步骤实现:
import  sys
exc_type, exc_value, exc_tb = sys.exc_info()
traceback.print_exception(exc_type,exc_value,exc_tb)


转载于:https://www.cnblogs.com/chargeworld/p/11515638.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值