一般网上的教程和博客都是基于py2.7,我是从3.5学起。一路上遇到的最大拦路虎是版本更迭带来的语法改变,我的时间都花在找出2.7-3.0的差异上了,真实可气啊。
其中的file.truncate貌似变化最大?
如果给入参,和2.7一样如预期。
例如:
woo.txt
1oooooo
2oooooo
3oooooo
4oooooo
f=open('woo.txt','r+')
f.truncate(5)
print(f.read())
f.close()
$ py truncate.py woo.txt
1oooo
$ type woo.txt
1oooo
但是教程中有一句话:truncate(size) 方法用于从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后 V 后面的所有字符被删除
语法如下:fileObject.truncate( [ size ])
于是我又试验了一次无size:
f=open('woo.txt','r+')
print(f.readline())
print(f.tell()) #9
f.truncate()
f.flush()
print(f.tell()) #9
f.seek(0)
print(f.read())
print(f.tell()) #34
f.close()
运行结果:
$ py truncate.py woo.txt
1oooooo
9
9
1oooooo
2oooooo
3oooooo
4oooooo
34
这是什么啊??? f.truncate()
后,应该截取了从seek(0)到当前指针位置(即f.tell()=9
)的字符,后面的全部删除,再次read()应该只得到一行1oooooo
,难道不是吗?
PS.附上我看的两页可恶的教程
Python File truncate()
Python3 File truncate()
PS.其中的Python3 File truncate()教程
号称针对python3.0,但前辈们看一下,此页教程里的truncate()简直无任何效果,去掉也不影响结果的。
我就想知道:truncate()在无参数下是不是失效了??
f.truncate()你没传size,所以没有改变大小
https://docs.python.org/3.5/l...
官网说明是如果你传的size比原来的文件小,那么从seek(size)之后的内容就会被删除,如果你传的size比原来大,会自动填充,填充什么取决于系统
Resize the stream to the given size in bytes (or the current position if size is not specified)
后半句如果没传参数,是当前postion