Heim > Backend-Entwicklung > PHP-Tutorial > Kopieren Sie den gesamten Inhalt eines Verzeichnisses in ein anderes Verzeichnis in PHP

Kopieren Sie den gesamten Inhalt eines Verzeichnisses in ein anderes Verzeichnis in PHP

WBOY
Freigeben: 2023-08-29 14:42:01
nach vorne
2200 Leute haben es durchsucht

Kopieren Sie den gesamten Inhalt eines Verzeichnisses in ein anderes Verzeichnis in PHP

Was ist PHP?

PHP steht für Hypertext Preprocessor und ist eine weit verbreitete serverseitige Skriptsprache, die hauptsächlich für die Webentwicklung verwendet wird. Es bietet Entwicklern eine leistungsstarke und flexible Plattform zum Erstellen dynamischer Webseiten und Anwendungen. PHP kann in HTML-Code eingebettet werden, was eine nahtlose Integration serverseitiger Funktionalität mit clientseitigen Elementen ermöglicht. Seine Syntax ähnelt der von C und Perl, was es für Programmierer, die mit diesen Sprachen vertraut sind, relativ einfach zu erlernen und zu verwenden macht. PHP ermöglicht die Ausführung serverseitiger Skripte auf einem Webserver und generiert so dynamische Inhalte, die an den Browser des Benutzers übermittelt werden können. Es unterstützt eine Vielzahl von Datenbanken und eignet sich für die Entwicklung datenbankgestützter Websites. Darüber hinaus bietet PHP ein umfangreiches Ökosystem an Open-Source-Bibliotheken und Frameworks, die eine schnelle Entwicklung ermöglichen und die Wiederverwendbarkeit von Code verbessern. Aufgrund seiner starken Community-Unterstützung und umfangreichen Dokumentation bleibt PHP eine beliebte Wahl unter Webentwicklern weltweit.

PHP Kopieren Sie den gesamten Inhalt eines Verzeichnisses in ein anderes Verzeichnis

Hier verwenden wir scandir() und die Klasse RecursiveIteratorIterator, um den gesamten Inhalt eines Verzeichnisses in ein anderes Verzeichnis zu kopieren.

Methode 1

Verwenden Sie scandir()

Dann akzeptiert scandir() eine Reihe von Argumenten und gibt, wenn keine Fehler auftreten, eine Liste der Dateinamen im Verzeichnis zurück.

Grammatik

array scandir(string $directory, int $sorting_order = 
SCANDIR_SORT_ASCENDING, resource|null $context = null)
Nach dem Login kopieren
  • $Verzeichnis (Zeichenfolge): Der Pfad zum zu scannenden Verzeichnis.

  • $sorting_order (int, optional): Gibt die Sortierreihenfolge der Ergebnisse an. Es kann einen der folgenden Werte annehmen:

  • SCANDIR_SORT_ASCENDING (Standard): Ergebnisse in aufsteigender Reihenfolge sortieren.

  • SCANDIR_SORT_DESCENDING: Ergebnisse in absteigender Reihenfolge sortieren.

  • SCANDIR_SORT_NONE: Es wird keine Sortierung durchgeführt.

  • $context (resource|null, optional): Gibt die Kontextressource an, die mit stream_context_create() erstellt wurde. Es wird verwendet, um das Verhalten der Funktion scandir() zu ändern. Wenn nicht angegeben, wird null verwendet.

  • Rückgabewert: Die Funktion scandir() gibt ein Array von Dateinamen und Verzeichnissen im angegebenen Verzeichnis zurück. Es umfasst reguläre Dateien und Verzeichnisse. Das resultierende Array enthält spezielle Einträge. und .. stellen das aktuelle Verzeichnis bzw. das übergeordnete Verzeichnis dar.

Beispiel

Hier ist ein Beispiel dafür, wie man mit scandir() den gesamten Inhalt eines Verzeichnisses in ein anderes Verzeichnis in PHP kopiert.

<?php
function copyDirectory($source, $destination) {
   if (!is_dir($destination)) {
      mkdir($destination, 0755, true);
   }
   $files = scandir($source);
   foreach ($files as $file) {
      if ($file !== '.' && $file !== '..') {
         $sourceFile = $source . '/' . $file;
         $destinationFile = $destination . '/' . $file;
         if (is_dir($sourceFile)) {
            copyDirectory($sourceFile, $destinationFile);
         } else {
            copy($sourceFile, $destinationFile);
         }
      }
   }
}
$sourceDirectory = '/source/directory';
$destinationDirectory = '/destination/directory';
copyDirectory($sourceDirectory, $destinationDirectory);
?>
Nach dem Login kopieren

Ausgabe

There will be no output if the process is successful.
Nach dem Login kopieren
Nach dem Login kopieren

Codebeschreibung

Dieser Code definiert eine Funktion namens copyDirectory, die für das rekursive Kopieren des Inhalts des Quellverzeichnisses in das Zielverzeichnis verantwortlich ist. Die Funktion prüft zunächst, ob das Zielverzeichnis nicht existiert und erstellt es ggf. mit mkdir(). Anschließend wird scandir() verwendet, um eine Liste der Dateien und Verzeichnisse im Quellverzeichnis abzurufen. Es durchläuft jedes Element, mit Ausnahme von .- und ..-Einträgen, und erstellt die Quell- und Zieldateipfade. Wenn es sich bei dem Element um ein Verzeichnis handelt, ruft sich die Funktion rekursiv mit dem neuen Pfad auf. Wenn es sich um eine Datei handelt, verwenden Sie die Funktion copy(), um die Datei von der Quelle zum Ziel zu kopieren. Dieser Vorgang wird fortgesetzt, bis alle Inhalte des Quellverzeichnisses in das Zielverzeichnis kopiert wurden, einschließlich der Unterverzeichnisse und ihrer jeweiligen Dateien. Abschließend wird die Funktion mit den als Argumenten bereitgestellten Quell- und Zielverzeichnissen aufgerufen, um den Kopiervorgang auszuführen.

Methode 2

Verwenden Sie die RecursiveIteratorIterator-Klasse mit RecursiveDirectoryIterator

Hier werden wir zwei Klassen verwenden, um die Aufgabe zu erledigen.

Grammatik

bool mkdir(string $pathname, int $mode = 0777, bool $recursive = 
false, resource|null $context = null)
Nach dem Login kopieren
Nach dem Login kopieren
  • $Pfadname (Zeichenfolge): Der Pfad zum zu erstellenden Verzeichnis.

  • $mode (int, optional): Berechtigungen zum Festlegen für das neu erstellte Verzeichnis. Die Angabe erfolgt als Oktalwert.

  • $rekursiv (boolean, optional): Wenn auf „true“ gesetzt, wird die rekursive Erstellung übergeordneter Verzeichnisse aktiviert.

  • $context (resource|null, optional): Gibt die Kontextressource an, die mit stream_context_create() erstellt wurde.

  • Rückgabewert: Die Funktion mkdir() gibt bei Erfolg „true“ und bei einem Fehler „false“ zurück.

Beispiel

Hier ist ein Beispiel für die Verwendung der oben genannten Methode.

function copyDirectory($source, $destination) {
   if (!is_dir($destination)) {
      mkdir($destination, 0755, true);
   }
   $iterator = new RecursiveIteratorIterator(
      new RecursiveDirectoryIterator($source, RecursiveDirectoryIterator::SKIP_DOTS),
      RecursiveIteratorIterator::SELF_FIRST
   );
   foreach ($iterator as $item) {
      if ($item->isDir()) {
         $dir = $destination . '/' . $iterator->getSubPathName();
         if (!is_dir($dir)) {
            mkdir($dir, 0755, true);
         }
      } else {
         $file = $destination . '/' . $iterator->getSubPathName();
         copy($item, $file);
      }
   }
}
$sourceDirectory = '/source/directory';
$destinationDirectory = '/destination/directory';
copyDirectory($sourceDirectory, $destinationDirectory);
Nach dem Login kopieren
Nach dem Login kopieren

Ausgabe

There will be no output if the process is successful.
Nach dem Login kopieren
Nach dem Login kopieren

Codebeschreibung:

Dieser Code definiert eine Funktion namens copyDirectory, die für das rekursive Kopieren des Inhalts des Quellverzeichnisses in das Zielverzeichnis verantwortlich ist. Die Funktion prüft zunächst, ob das Zielverzeichnis nicht existiert und erstellt es ggf. mit mkdir(). Anschließend wird scandir() verwendet, um eine Liste der Dateien und Verzeichnisse im Quellverzeichnis abzurufen. Es durchläuft jedes Element, mit Ausnahme von .- und ..-Einträgen, und erstellt die Quell- und Zieldateipfade. Wenn es sich bei dem Element um ein Verzeichnis handelt, ruft sich die Funktion rekursiv mit dem neuen Pfad auf. Wenn es sich um eine Datei handelt, verwenden Sie die Funktion copy(), um die Datei von der Quelle zum Ziel zu kopieren. Dieser Vorgang wird fortgesetzt, bis alle Inhalte des Quellverzeichnisses in das Zielverzeichnis kopiert wurden, einschließlich der Unterverzeichnisse und ihrer jeweiligen Dateien. Abschließend wird die Funktion mit den als Argumenten bereitgestellten Quell- und Zielverzeichnissen aufgerufen, um den Kopiervorgang auszuführen.

方法2

将 RecursiveIteratorIterator 类与 RecursiveDirectoryIterator 一起使用

这里我们将使用两个类来完成任务。

语法

bool mkdir(string $pathname, int $mode = 0777, bool $recursive = 
false, resource|null $context = null)
Nach dem Login kopieren
Nach dem Login kopieren
  • $pathname(字符串):要创建的目录的路径。

  • $mode(int,可选):为新创建的目录设置的权限。它被指定为八进制值。

  • $recursive(布尔型,可选):如果设置为 true,则启用父目录的递归创建。

  • $context(resource|null,可选):指定使用stream_context_create()创建的上下文资源。

  • 返回值:mkdir() 函数在成功时返回 true,在失败时返回 false。

示例

这里是使用上述方法的一个例子。

function copyDirectory($source, $destination) {
   if (!is_dir($destination)) {
      mkdir($destination, 0755, true);
   }
   $iterator = new RecursiveIteratorIterator(
      new RecursiveDirectoryIterator($source, RecursiveDirectoryIterator::SKIP_DOTS),
      RecursiveIteratorIterator::SELF_FIRST
   );
   foreach ($iterator as $item) {
      if ($item->isDir()) {
         $dir = $destination . '/' . $iterator->getSubPathName();
         if (!is_dir($dir)) {
            mkdir($dir, 0755, true);
         }
      } else {
         $file = $destination . '/' . $iterator->getSubPathName();
         copy($item, $file);
      }
   }
}
$sourceDirectory = '/source/directory';
$destinationDirectory = '/destination/directory';
copyDirectory($sourceDirectory, $destinationDirectory);
Nach dem Login kopieren
Nach dem Login kopieren

代码说明

在此方法中,RecursiveDirectoryIterator 用于迭代目录结构,包括所有子目录和文件。 RecursiveIteratorIterator 有助于递归地遍历迭代器。它会跳过 .和 .. 使用 SKIP_DOTS 标志的条目。在循环内,它检查当前项是否是目录。如果是这样,它会使用 mkdir() 在目标路径中创建相应的目录(如果该目录尚不存在)。如果该项目是文件,它将构造目标文件路径并使用 copy() 复制文件。此方法消除了对单独递归函数的需要,并通过利用内置 PHP 迭代器类的功能简化了代码。

结论

综上所述,两种方法都可以达到预期的结果,但第二种使用迭代器的方法提供了更优雅、更高效的解决方案,特别是对于涉及大型目录结构的场景。不过,这两种方法的选择最终取决于开发者的具体要求和偏好。

Das obige ist der detaillierte Inhalt vonKopieren Sie den gesamten Inhalt eines Verzeichnisses in ein anderes Verzeichnis in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:tutorialspoint.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage