Как включить () все файлы PHP из каталога?

Очень быстрый вопрос n00b, в PHP я могу включить каталог скриптов.

т.е. вместо:

include('classes/Class1.php'); include('classes/Class2.php'); 

есть что-то вроде:

 include('classes/*'); 

Не похоже, чтобы найти хороший способ включить коллекцию из примерно 10 подклассов для определенного класса.

 foreach (glob("classes/*.php") as $filename) { include $filename; } 

Вот как я включаю много классов из нескольких папок в PHP 5. Это будет работать, только если у вас есть классы.

 /*Directories that contain classes*/ $classesDir = array ( ROOT_DIR.'classes/', ROOT_DIR.'firephp/', ROOT_DIR.'includes/' ); function __autoload($class_name) { global $classesDir; foreach ($classesDir as $directory) { if (file_exists($directory . $class_name . '.php')) { require_once ($directory . $class_name . '.php'); return; } } } 

Я понимаю, что это более старое сообщение, НО … НЕ ВКЛЮЧАЙТЕ ВАШИ КЛАССЫ … вместо этого используйте __autoload

 function __autoload($class_name) { require_once('classes/'.$class_name.'.class.php'); } $user = new User(); 

Затем, когда вы вызываете новый класс, который еще не был включен, php автоматически запускает __autoload и включает его для вас

это всего лишь модификация кода Карстен

 function include_all_php($folder){ foreach (glob("{$folder}/*.php") as $filename) { include $filename; } } include_all_php("my_classes"); 

Если вы используете php 5, вместо этого вы можете использовать автозагрузку .

Как это сделать в 2017 году:

 spl_autoload_register( function ($class_name) { $CLASSES_DIR = __DIR__ . DIRECTORY_SEPARATOR . 'classes' . DIRECTORY_SEPARATOR; // or whatever your directory is $file = $CLASSES_DIR . $class_name . '.php'; if( file_exists( $file ) ) include $file; // only include if file exists, otherwise we might enter some conflicts with other pieces of code which are also using the spl_autoload_register function } ); 

Рекомендуется для документации PHP здесь: классы автозагрузки

Вы можете использовать set_include_path :

 set_include_path('classes/'); 

http://php.net/manual/en/function.set-include-path.php

Если вы хотите включить все в каталог И его подкаталоги:

 $dir = "classes/"; $dh = opendir($dir); $dir_list = array($dir); while (false !== ($filename = readdir($dh))) { if($filename!="."&&$filename!=".."&&is_dir($dir.$filename)) array_push($dir_list, $dir.$filename."/"); } foreach ($dir_list as $dir) { foreach (glob($dir."*.php") as $filename) require_once $filename; } 

Не забывайте, что он будет использовать буквенный порядок для включения ваших файлов.

Если между файлами нет НИКАКИХ зависимостей … вот рекурсивная функция для include_once ВСЕ php-файлов во всех поддиректорах ALL:

 $paths = array(); function include_recursive( $path, $debug=false){ foreach( glob( "$path/*") as $filename){ if( strpos( $filename, '.php') !== FALSE){ # php files: include_once $filename; if( $debug) echo "<!-- included: $filename -->\n"; } else { # dirs $paths[] = $filename; } } # Time to process the dirs: for( $i=count($paths)-1; $i>0; $i--){ $path = $paths[$i]; unset( $paths[$i]); include_recursive( $path); } } include_recursive( "tree_to_include"); # or... to view debug in page source: include_recursive( "tree_to_include", 'debug'); 

Я предлагаю вам использовать функцию readdir (), а затем цикл и включить файлы (см. Первый пример на этой странице).

Если вы хотите включить кучу классов без необходимости определять каждый класс сразу, вы можете использовать:

 $directories = array( 'system/', 'system/db/', 'system/common/' ); foreach ($directories as $directory) { foreach(glob($directory . "*.php") as $class) { include_once $class; } } 

Таким образом, вы можете просто определить класс в файле php, содержащий класс, а не весь список $thisclass = new thisclass();

Что касается того, насколько хорошо он обрабатывает все файлы? Я не уверен, что с этим может быть небольшое снижение скорости.

Не записывайте функцию () для включения файлов в каталог. Вы можете потерять переменные области и, возможно, придется использовать «глобальный». Просто зациклируйте файлы.

Кроме того, вы можете столкнуться с трудностями, когда включенный файл имеет имя класса, которое будет распространено на другой класс, определенный в другом файле, который еще не включен. Так что будь осторожен.