2012-02-03 21 views

Odpowiedz

8

ten powinien być minimalny kod wymagany:

#include <fstream> 

// copy in binary mode 
bool copyFile(const char *SRC, const char* DEST) 
{ 
    std::ifstream src(SRC, std::ios::binary); 
    std::ofstream dest(DEST, std::ios::binary); 
    dest << src.rdbuf(); 
    return src && dest; 
} 

int main(int argc, char *argv[]) 
{ 
    return copyFile(argv[1], argv[2]) ? 0 : 1; 
} 

to błyszczyki wokół niektórych potencjalnie skomplikowanych zagadnień: obsługę błędów, znak nazwy pliku kodowania ... ale może dać ci start.

-1

Poniższy kod kopiuje wszystkie pliki z jednego katalogu do drugiego.

swój kod pracujących w C++

#include <windows.h> 

/* 
BOOL Copy(char r_szPath[1024], char r_szDir[1024]) 
{ 
char l_szTemp[2048] = {0}; 
sprintf(l_szTemp,"%s\%s"r_szPath,r_szDir); 

if(IsDirectory(
}*/ 

#include <stdio.h> 
#include<conio.h> 

BOOL __Copy(char r_szSrcPath[1024],char r_szDesPath[1024]) 
{ 
WIN32_FIND_DATA FindFileData; 
HANDLE hFind; 
char l_szTmp[1025] = {0}; 
memcpy(l_szTmp,r_szSrcPath,1024); 


char l_szSrcPath[1025] = {0}; 
char l_szDesPath[1025] = {0}; 
memcpy(l_szSrcPath,r_szSrcPath,1024); 
memcpy(l_szDesPath,r_szDesPath,1024); 

char l_szNewSrcPath[1025] = {0}; 
char l_szNewDesPath[1025] = {0}; 

strcat(l_szTmp,"*"); 

hFind = FindFirstFile(l_szTmp, &FindFileData); 
if(hFind == NULL) return FALSE; 

do 
{ 

if(FindFileData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) 
{ 
if(strcmp(FindFileData.cFileName,".")) 
{ 
if(strcmp(FindFileData.cFileName,"..")) 
{ 
printf ("The Directory found is %s<BR>, FindFileData.cFileName); 

sprintf(l_szNewDesPath,"%s%s\",l_szDesPath,FindFileData.cFileName); 

sprintf(l_szNewSrcPath,"%s%s\",l_szSrcPath,FindFileData.cFileName); 
CreateDirectory(l_szNewDesPath,NULL); 
__Copy(l_szNewSrcPath,l_szNewDesPath); 
} 
} 
} 
else 
{ 
printf ("The File found is %s<BR>, FindFileData.cFileName); 
char l_szSrcFile[1025] = {0}; 
char l_szDesFile[1025] = {0}; 
sprintf(l_szDesFile,"%s%s",l_szDesPath,FindFileData.cFileName); 
sprintf(l_szSrcFile,"%s%s",l_szSrcPath,FindFileData.cFileName); 
BOOL l_bRet = CopyFile(l_szSrcFile,l_szDesFile,TRUE); 

} 


} 
while(FindNextFile(hFind, &FindFileData)); 
FindClose(hFind); 
return TRUE; 
} 


int main(int argc, char *argv[]) 
{ 
__Copy("C:\fcdb\","E:\sandy\"); 
getch(); 
return 0; 
} 
+4

witamy w SO ... aby ulepszyć twój post, rozważ usunięcie go lub rozwiązując te problemy 1. to nie działa kod, masz mnóstwo błędów w swoich instrukcjach if dotyczących "." i ".." .. i nie zapomnij literówki w swoim miejscu, w którym pominięto spację. 2. nie odpowiedziałeś na to pytanie. Odpowiedziałeś na pytanie, które utworzyłeś. 3. pytanie dotyczy C++ i Ubuntu ... używanie specyficznych dla systemu Windows rzeczy nie jest tutaj użyteczne 4. Proszę wcięcie kodu tak, aby było czytelne – UpAndAdam

0

Z std::filesystem::copy_file z C++ 17:

#include <exception> 
#include <filesystem> 
#include <iostream> 

namespace fs = std::filesystem; 

int main() 
{ 
    fs::path sourceFile = "path/to/sourceFile.ext"; 
    fs::path targetParent = "path/to/target"; 
    auto target = targetParent/sourceFile.filename(); // sourceFile.filename() returns "sourceFile.ext". 

    try // If you want to avoid exception handling, then use the error code overload of the following functions. 
    { 
     fs::create_directories(targetParent); // Recursively create target directory if not existing. 
     fs::copy_file(sourceFile, target, fs::copy_options::overwrite_existing); 
    } 
    catch (std::exception& e) // Not using fs::filesystem_error since std::bad_alloc can throw too. 
    { 
     std::cout << e.what(); 
    } 
} 

Użyłem std::filesystem::path::filename celu pobrania pliku źródłowego bez konieczności go wpisać ręcznie. Jednak z std::filesystem::copy można pominąć przechodzącą nazwy pliku do ścieżki docelowej w ogóle:

fs::copy(sourceFile, targetParent, fs::copy_options::overwrite_existing); 

zmienić zachowanie obu funkcji z std::filesystem::copy_options.

Powiązane problemy