Respostas:
shutil
tem muitos métodos que você pode usar. Um dos quais é:
from shutil import copyfile
copyfile(src, dst)
Se você usar os.path
operações, use em copy
vez de copyfile
. copyfile
vai aceitar apenas cordas .
~
, mas pode lidar com caminhos relativos
┌──────────────────┬────────┬───────────┬───────┬────────────────┐
│ Function │ Copies │ Copies │Can use│ Destination │
│ │metadata│permissions│buffer │may be directory│
├──────────────────┼────────┼───────────┼───────┼────────────────┤
│shutil.copy │ No │ Yes │ No │ Yes │
│shutil.copyfile │ No │ No │ No │ No │
│shutil.copy2 │ Yes │ Yes │ No │ Yes │
│shutil.copyfileobj│ No │ No │ Yes │ No │
└──────────────────┴────────┴───────────┴───────┴────────────────┘
copy2(src,dst)
geralmente é mais útil do que copyfile(src,dst)
porque:
dst
ser um diretório (em vez do nome completo do nome do arquivo); nesse caso, o nome da base src
é usado para criar o novo arquivo;Aqui está um pequeno exemplo:
import shutil
shutil.copy2('/src/dir/file.ext', '/dst/dir/newname.ext') # complete target filename given
shutil.copy2('/src/file.ext', '/dst/dir') # target filename is /dst/dir/file.ext
copyfile
é consideravelmente mais rápido do quecopy2
shutil.copy2('/dir/file.ext', '/new/dir/')
(com barra após o caminho de destino) removerá a ambiguidade sobre copiar para um novo arquivo chamado "dir" ou colocar o arquivo em um diretório com esse nome?
/new/dir
houver um diretório existente, consulte o comentário de @ MatthewAlpert.
/new/dir/
não existir, o Python lançará um IsADirectoryError
, caso contrário, ele copiará o arquivo para /new/dir/
o nome original.
Você pode usar uma das funções de cópia do shutil
pacote:
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━ A função preserva suportes aceita cópias de outros diretório de permissões dest. metadados do objeto de arquivo ― ― ― ― ― ― ―――――――――――――――――――――――― shutil.copy ✔ ☐ shutil.copy2 ✔ ✔ ✔ shutil.copyfile ☐ ☐ ☐ shutil.copyfileobj ☐ ☐ ✔ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━
Exemplo:
import shutil
shutil.copy('/etc/hostname', '/var/tmp/testhostname')
No Python, você pode copiar os arquivos usando
shutil
móduloos
módulosubprocess
móduloimport os
import shutil
import subprocess
shutil
móduloshutil.copyfile
assinatura
shutil.copyfile(src_file, dest_file, *, follow_symlinks=True)
# example
shutil.copyfile('source.txt', 'destination.txt')
shutil.copy
assinatura
shutil.copy(src_file, dest_file, *, follow_symlinks=True)
# example
shutil.copy('source.txt', 'destination.txt')
shutil.copy2
assinatura
shutil.copy2(src_file, dest_file, *, follow_symlinks=True)
# example
shutil.copy2('source.txt', 'destination.txt')
shutil.copyfileobj
assinatura
shutil.copyfileobj(src_file_object, dest_file_object[, length])
# example
file_src = 'source.txt'
f_src = open(file_src, 'rb')
file_dest = 'destination.txt'
f_dest = open(file_dest, 'wb')
shutil.copyfileobj(f_src, f_dest)
os
móduloos.popen
assinatura
os.popen(cmd[, mode[, bufsize]])
# example
# In Unix/Linux
os.popen('cp source.txt destination.txt')
# In Windows
os.popen('copy source.txt destination.txt')
os.system
assinatura
os.system(command)
# In Linux/Unix
os.system('cp source.txt destination.txt')
# In Windows
os.system('copy source.txt destination.txt')
subprocess
módulosubprocess.call
assinatura
subprocess.call(args, *, stdin=None, stdout=None, stderr=None, shell=False)
# example (WARNING: setting `shell=True` might be a security-risk)
# In Linux/Unix
status = subprocess.call('cp source.txt destination.txt', shell=True)
# In Windows
status = subprocess.call('copy source.txt destination.txt', shell=True)
subprocess.check_output
assinatura
subprocess.check_output(args, *, stdin=None, stderr=None, shell=False, universal_newlines=False)
# example (WARNING: setting `shell=True` might be a security-risk)
# In Linux/Unix
status = subprocess.check_output('cp source.txt destination.txt', shell=True)
# In Windows
status = subprocess.check_output('copy source.txt destination.txt', shell=True)
['copy', sourcefile, destfile]
sintaxe sempre que possível, especialmente se os parâmetros forem da entrada do usuário.
os.popen
está obsoleto por um tempo agora. e check_output
não retorna o status, mas a saída (que está vazia no caso de copy/cp
)
Copiar um arquivo é uma operação relativamente direta, como mostra os exemplos abaixo, mas você deve usar o módulo shutil stdlib para isso.
def copyfileobj_example(source, dest, buffer_size=1024*1024):
"""
Copy a file from source to dest. source and dest
must be file-like objects, i.e. any object with a read or
write method, like for example StringIO.
"""
while True:
copy_buffer = source.read(buffer_size)
if not copy_buffer:
break
dest.write(copy_buffer)
Se você deseja copiar por nome de arquivo, você pode fazer algo assim:
def copyfile_example(source, dest):
# Beware, this example does not handle any edge cases!
with open(source, 'rb') as src, open(dest, 'wb') as dst:
copyfileobj_example(src, dst)
shutil.copyfileobj
. Além disso, você não precisa try, finally
lidar com o fechamento dos arquivos após exceções. Eu diria, no entanto, que sua função não deve ser responsável por abrir e fechar os arquivos. Isso deve incluir uma função de invólucro, como os shutil.copyfile
envoltórios shutil.copyfileobj
.
dest
para ser gravável:open(dest, 'wb')
Use o módulo shutil .
copyfile(src, dst)
Copie o conteúdo do arquivo chamado src para um arquivo chamado dst. O local de destino deve ser gravável; caso contrário, uma exceção IOError será gerada. Se o dst já existir, será substituído. Arquivos especiais como dispositivos de caractere ou bloco e tubulações não podem ser copiados com esta função. src e dst são nomes de caminho dados como strings.
Dê uma olhada no filesys para todas as funções de manipulação de arquivos e diretórios disponíveis nos módulos padrão do Python.
Exemplo de cópia de diretório e arquivo - do Python de Tim Golden:
http://timgolden.me.uk/python/win32_how_do_i/copy-a-file.html
import os
import shutil
import tempfile
filename1 = tempfile.mktemp (".txt")
open (filename1, "w").close ()
filename2 = filename1 + ".copy"
print filename1, "=>", filename2
shutil.copy (filename1, filename2)
if os.path.isfile (filename2): print "Success"
dirname1 = tempfile.mktemp (".dir")
os.mkdir (dirname1)
dirname2 = dirname1 + ".copy"
print dirname1, "=>", dirname2
shutil.copytree (dirname1, dirname2)
if os.path.isdir (dirname2): print "Success"
Em primeiro lugar, fiz uma cheatsheet exaustiva dos métodos shutil para sua referência.
shutil_methods =
{'copy':['shutil.copyfileobj',
'shutil.copyfile',
'shutil.copymode',
'shutil.copystat',
'shutil.copy',
'shutil.copy2',
'shutil.copytree',],
'move':['shutil.rmtree',
'shutil.move',],
'exception': ['exception shutil.SameFileError',
'exception shutil.Error'],
'others':['shutil.disk_usage',
'shutil.chown',
'shutil.which',
'shutil.ignore_patterns',]
}
Em segundo lugar, explique os métodos de cópia nos exemplos:
shutil.copyfileobj(fsrc, fdst[, length])
manipular objetos abertos
In [3]: src = '~/Documents/Head+First+SQL.pdf'
In [4]: dst = '~/desktop'
In [5]: shutil.copyfileobj(src, dst)
AttributeError: 'str' object has no attribute 'read'
#copy the file object
In [7]: with open(src, 'rb') as f1,open(os.path.join(dst,'test.pdf'), 'wb') as f2:
...: shutil.copyfileobj(f1, f2)
In [8]: os.stat(os.path.join(dst,'test.pdf'))
Out[8]: os.stat_result(st_mode=33188, st_ino=8598319475, st_dev=16777220, st_nlink=1, st_uid=501, st_gid=20, st_size=13507926, st_atime=1516067347, st_mtime=1516067335, st_ctime=1516067345)
shutil.copyfile(src, dst, *, follow_symlinks=True)
Copie e renomeie
In [9]: shutil.copyfile(src, dst)
IsADirectoryError: [Errno 21] Is a directory: ~/desktop'
#so dst should be a filename instead of a directory name
shutil.copy()
Copiar sem preservar os metadados
In [10]: shutil.copy(src, dst)
Out[10]: ~/desktop/Head+First+SQL.pdf'
#check their metadata
In [25]: os.stat(src)
Out[25]: os.stat_result(st_mode=33188, st_ino=597749, st_dev=16777220, st_nlink=1, st_uid=501, st_gid=20, st_size=13507926, st_atime=1516066425, st_mtime=1493698739, st_ctime=1514871215)
In [26]: os.stat(os.path.join(dst, 'Head+First+SQL.pdf'))
Out[26]: os.stat_result(st_mode=33188, st_ino=8598313736, st_dev=16777220, st_nlink=1, st_uid=501, st_gid=20, st_size=13507926, st_atime=1516066427, st_mtime=1516066425, st_ctime=1516066425)
# st_atime,st_mtime,st_ctime changed
shutil.copy2()
Copiar preservando os metadados
In [30]: shutil.copy2(src, dst)
Out[30]: ~/desktop/Head+First+SQL.pdf'
In [31]: os.stat(src)
Out[31]: os.stat_result(st_mode=33188, st_ino=597749, st_dev=16777220, st_nlink=1, st_uid=501, st_gid=20, st_size=13507926, st_atime=1516067055, st_mtime=1493698739, st_ctime=1514871215)
In [32]: os.stat(os.path.join(dst, 'Head+First+SQL.pdf'))
Out[32]: os.stat_result(st_mode=33188, st_ino=8598313736, st_dev=16777220, st_nlink=1, st_uid=501, st_gid=20, st_size=13507926, st_atime=1516067063, st_mtime=1493698739, st_ctime=1516067055)
# Preseved st_mtime
shutil.copytree()
Copie recursivamente uma árvore de diretórios inteira enraizada no src, retornando o diretório de destino
Para arquivos pequenos e usando apenas built-ins python, você pode usar o seguinte recurso:
with open(source, 'rb') as src, open(dest, 'wb') as dst: dst.write(src.read())
Como o @maxschlepzig mencionado nos comentários abaixo, esta não é a maneira ideal para aplicativos em que o arquivo é muito grande ou quando a memória é crítica, portanto, a resposta de Swati deve ser a preferida.
.read()
e .write()
são armazenados em buffer por padrão (pelo menos para CPython).
open()
IO em buffer, por padrão, não ajuda aqui, porque read()
é especificado como: 'Se n for negativo ou omitido, leia até EOF'. Isso significa que read()
retorna o conteúdo completo do arquivo como uma sequência.
Você poderia usar os.system('cp nameoffilegeneratedbyprogram /otherdirectory/')
ou como eu fiz isso,
os.system('cp '+ rawfile + ' rawdata.dat')
Onde rawfile
está o nome que eu havia gerado dentro do programa.
Esta é uma solução apenas para Linux
shutil
não está disponível - subprocess.run()
(sem shell=True
!) É a melhor alternativa para os.system()
.
subprocess.run()
como sugerido por @maxschlepzig, é um grande passo em frente ao chamar programas externos. Para flexibilidade e segurança, no entanto, use a ['cp', rawfile, 'rawdata.dat']
forma de passar a linha de comando. (No entanto, para cópia, shutil
e os amigos são mais recomendadas que chamar um programa externo.)
Para arquivos grandes, o que eu fiz foi ler o arquivo linha por linha e ler cada linha em uma matriz. Depois que o array atingir um determinado tamanho, anexe-o a um novo arquivo.
for line in open("file.txt", "r"):
list.append(line)
if len(list) == 1000000:
output.writelines(list)
del list[:]
for l in open('file.txt','r'): output.write(l)
deve trabalhar encontrar; basta configurar o buffer do fluxo de saída de acordo com suas necessidades. ou você pode acessar os bytes repetindo uma tentativa com output.write(read(n)); output.flush()
onde n
está o número de bytes que você deseja escrever por vez. ambos também não têm condições de verificar qual é um bônus.
shutil
? Mesmo quando ignorado shutil
, um simples loop de leitura / gravação de bloco (usando IO sem buffer) é direto, seria eficiente e faria muito mais sentido do que isso e, portanto, é certamente mais fácil de ensinar e entender.
from subprocess import call
call("cp -p <file> <file>", shell=True)
call
é inseguro. Consulte os subprocessos sobre isso.
No Python 3.5, você pode fazer o seguinte para arquivos pequenos (por exemplo: arquivos de texto, jpegs pequenos):
from pathlib import Path
source = Path('../path/to/my/file.txt')
destination = Path('../path/where/i/want/to/store/it.txt')
destination.write_bytes(source.read_bytes())
write_bytes
substituirá o que estava no local de destino
shutil
lida com todos os casos especiais para você e oferece tranqüilidade.
open(destination, 'wb').write(open(source, 'rb').read())
Abra o arquivo de origem no modo de leitura e grave no arquivo de destino no modo de gravação.
.close()
em todos esses open(...)
s?
O Python fornece funções integradas para copiar facilmente arquivos usando os utilitários de shell do sistema operacional.
O comando a seguir é usado para copiar arquivo
shutil.copy(src,dst)
O comando a seguir é usado para Copiar Arquivo com Informações MetaData
shutil.copystat(src,dst)
copy
então copystat
para preservar os metadados do arquivo. No Python 3.3+ copystat
também copia atributos estendidos.