1
2
3
4
5
6
7
8
|
import os
old_file_name = input ( "Please input what's file do you want to copy go:" )
fp = open (old_file_name)
content = fp.read()
index = old_file_name.rfind( '.' )
new_file_name = old_file_name[:index] + "[复件]" + old_file_name[index:]
dp = open (new_file_name, 'w' )
dp.write(content) |
上面代码是文件的复制,我们的思路是这样的:
你可以打开一个存在的文件,然后去读取这个文件的内容,然后去创建一个新的文件,这个文件的名字是旧文件名字后面加上[复件]这样的字体。然后把我们刚刚在旧文件中读到的内容写到新文件里面去。关闭两个文件就好啦。
第二行让用户输入你想复制的文件,这个文件必须存在,而且最好是绝对路径。
第四行是打开我们要旧文件,用content变量是保存旧文件里面的内容
第五行去查找old_file_name这个变量的字符串中最右边出现的一个'.'符号的下标。
第六行是给new文件命名,然后赋予给变量new_file_name这个变量啊
那么上面有一个问题,如果说我们要复制一个你不知多大的文件的时候,千万不要用read,因为read会把所有的内容都读进内存,如果这个文件很大你的内存就崩了,也不要用readlines因为如果你的文件内容只有一行,这一行的数据很大,那你的内存也会被影响到。
可以用下面代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
import os
old_file_name = input ( "Please input what's file do you want to copy go:" )
fp = open (old_file_name)
index = old_file_name.rfind( '.' )
new_file_name = old_file_name[:index] + "[复件]" + old_file_name[index:]
dp = open (new_file_name, 'w' )
while True :
content = fp.read( 1024 )
if len (content) = = 0 :
break
dp.write(content)
fp.close() dp.close() |
上面代码的第8行是读这个文件的前1024个字符,然后再去判断读出来的内容是不是为空的,如果是的话就break退出循环,如果不是就就把内容写入新文件中
本文转自 周子琪 51CTO博客,原文链接:http://blog.51cto.com/izhouyu/1967644