찾다
백엔드 개발PHP 튜토리얼[散分]生活便利小代码,拍照后,批量递归缩放目录图片.

新入手单反一周了,今天终于找上了机会带上老婆老妈去荔枝公园拍了一天的照,回来准备上传至相册,突然发现,每张图片都有点偏大,找工具也很累,直接上网,东拼西凑了点代码.实现将指定目录的图片,按指定大小范围缩放并输出到指定目录(含递归) ,供自己以后处理相片使用. 不多废话了,附代码.

    header('Content-type:text/html; charset=utf-8');    require "lib/imgHelper.php";    $imgHelper = new imgHelper( "dir1" );    $imgHelper->setOutputDir( "dir2" );    //默认输出在1024 768 下等比缩放,需要自定义时,$imgHelper->setOutputSize(1440,900);    $imgHelper->execution();

lib 库代码.
<?php/** * 图片处理助手 */class imgHelper{    public $srcFiles;     //源文件   array    public $srcDirs;      //源目录    public $exportDir;    //输出目录    public $exportFiles;  //输出文件  array    private  $_option = array("maxWidth"=>"1024" , "maxHeight"=>"768");    function __construct($dir = '' , $option = array() )    {        if (!$dir) return;        $this->srcDirs = $dir;        $this->srcFiles = $this->traversal($dir);        $this->setOptions( $option );    }    /**     * 设置输出目录     * @param $dir     */    public function setOutputDir( $dir )    {        if( !is_dir( $dir )) { mkdir($dir , 0777 , 1);}            $this->exportDir = $dir;    }    public function execution()    {       foreach( $this->srcFiles as $key =>$val ):           $srcImg = $val;           $toFile = str_replace( $this->srcDirs , $this->exportDir , $srcImg); //todo 简便处理.           $maxWidth = $this->_option["maxWidth"];           $maxHeight = $this->_option["maxHeight"];           $this->resize($srcImg , $toFile , $maxWidth , $maxHeight );       endforeach;    }    //缩放图片.    private  function resize($srcImage,$toFile,$maxWidth = 100,$maxHeight = 100,$imgQuality=100)    {            //创建目录目录!            $pInfo = pathinfo( $toFile );            $dir = $pInfo["dirname"];  if(!is_dir( $dir) ){ mkdir($dir , 0777 , 1);}            list($width, $height, $type, $attr) = getimagesize($srcImage);            if($width < $maxWidth  || $height < $maxHeight) return ;            switch ($type) {                case 1: $img = imagecreatefromgif($srcImage); break;                case 2: $img = imagecreatefromjpeg($srcImage); break;                case 3: $img = imagecreatefrompng($srcImage); break;            }            $scale = min($maxWidth/$width, $maxHeight/$height); //求出绽放比例            if($scale < 1) {                $newWidth = floor($scale*$width);                $newHeight = floor($scale*$height);                $newImg = imagecreatetruecolor($newWidth, $newHeight);                imagecopyresampled($newImg, $img, 0, 0, 0, 0, $newWidth, $newHeight, $width, $height);                $newName = "";                $toFile = preg_replace("/(.gif|.jpg|.jpeg|.png)/i","",$toFile);                switch($type) {                    case 1: if(imagegif($newImg, "$toFile$newName.gif", $imgQuality))                        return "$newName.gif"; break;                    case 2: if(imagejpeg($newImg, "$toFile$newName.jpg", $imgQuality))                        return "$newName.jpg"; break;                    case 3: if(imagepng($newImg, "$toFile$newName.png", $imgQuality))                        return "$newName.png"; break;                    default: if(imagejpeg($newImg, "$toFile$newName.jpg", $imgQuality))                        return "$newName.jpg"; break;                }                imagedestroy($newImg);            }            imagedestroy($img);            return false;    }    /**     * 设置输出的大小     * @param string $width     * @param string $height     */    public function setOutputSize( $width = "1024" , $height = "768"){        $_option = array("maxWidth"=>"$width" , "maxHeight"=>"$height");        $this->setOptions( $_option );    }    /**     * 设置可选参数     * @param $option     */    private  function setOptions( $option)    {        foreach( $option as $key =>$val):            if( isset( $option[$key]) && $option[$key] ){                $this->_option[$key] = $val;            }        endforeach;    }    /**     * 遍得到文件夹下的所有文件     */    private function traversal($path)    {        if (!$path) return array();        $files = array();        if (!is_dir($path)) return;        foreach (scandir($path) as $file)        {            if ($file != '.' && $file != '..') {                $path2 = $path . '/' . $file;                if (is_dir($path2)) {                    $temp = $this->traversal($path2);                    $files = array_merge($files, $temp);                } else {                    if ($this->isIMg($file)) {                        $files[] = $path . "/" . $file;                    }                }            }        }        return $files;    }    /**     * 判断是否是图片     * @param $file     * @return bool     */    private function isIMg($file)   {        $pInfo  = pathinfo( $file);         $extention =  $pInfo["extension"];        return  preg_match("/(jpg)|(png)|gif/i" , $extention);    }    /** * 调试数据 */    public  function debug() {$this->pr($this->srcFiles, "待处理图片数组.");          $this->pr( $this->srcDirs , "源目录");          $this->pr( $this->exportDir , "目标目录");    }    private function  pr($array, $title = 'DEBUG', $type = 'array', $width = '')  {      /*** @格式化输出 */        $title .= date("Y-m-d H:i:s");        $widthStr = "";        if ($width) $widthStr = "width:$width" . "px";        echo "<fieldset style=\"-moz-border-radius:5px 5px 5px 5px; -moz-box-shadow:0px 0px 10px rgba(00,00,00,0.45); border: 3px solid  transparent; padding:3px; margin-top:20px; \"><legend style=\"color: #069; margin:3px; $widthStr \">$title</legend>";        echo "<div style = '-moz-border-radius:10px 10px 10px 10px;font-size:14px; color:#069; border:1px solid #F0FAF9;  font-size:9pt; background:#F0FAF9; padding:5px;'>";        print("<pre class="brush:php;toolbar:false">");        if ($type == 'json') {  $array = json_decode($array);    }        print_r($array);        print("
");        echo "

";        echo  "";    }}


回复讨论(解决方案)

刚运行了一下,发现图片太多,运行时间不够,加一句 ini_set('max_execute_time',3600); 即可.

晕一个 上面的写错了,更正为 max_execution_time 

代码没收了~~很好。

回帖超过30楼,送今日偷拍美女照片一张!

... ... 
有点吗?有点嘛?有点啊?!
回帖超过30楼,送今日偷拍美女照片一张!

哈哈,类收起,....

           $maxWidth = $this->_option["maxWidth"];
           $maxHeight = $this->_option["maxHeight"];
放到循环外不是更好些?

resize 方法显得很臃肿

进来看看

这个不错,收藏一下,要用到


最近照了3k多张图片约20G图片,本以为程序写好后,就happy 的在运行转换了,谁知,当我当睡没多久,电脑遭遇老妈黑手,直接断电式关机.打开一看,只转了400张,再次运行,这400张图片将重复操作,于是折腾了一下代码,将重复去掉,并追加日志记录功能.

//在class imgHelper 内.添加如下代码.        private $copyOverWrite = true;    private $isLog = true;    /**     * 设置是否日志记录     * @param $bool     */    public function setIsLog( $bool )    {            $this->isLog = $bool;    }    /**     * 设置是否覆盖     * @param $bool     */    public function setCopyOverWrite( $bool ){        $this->copyOverWrite = $bool;    }    //记录日志.    private function log( $str ,$title = '图片助手日志' )    {        $logFile ="log/".date("Y-m-d").".log";        $pInfo = pathinfo( $logFile );        $dir = $pInfo["dirname"];  if(!is_dir( $dir) ){ mkdir($dir , 0777 , 1);}        $str =  date("H:i:s").$str . "\n";        file_put_contents($logFile, $str,FILE_APPEND);    }


//对function resize() 进行修改//追加至首行.          if( !$this->copyOverWrite && is_file($toFile)) //当设置为不覆盖,以及文件已存在时,跳过            {                 $this->log("$toFile 已存在,且系统设置为不覆盖,将做跳过处理","操作提示");                  return ;            }            $this->log( "正在努力的生成 $toFile " );//修改后 private  function resize($srcImage,$toFile,$maxWidth = 100,$maxHeight = 100,$imgQuality=100)    {            if( !$this->copyOverWrite && is_file($toFile)) //当设置为不覆盖,以及文件已存在时,跳过            {                 $this->log("$toFile 已存在,且系统设置为不覆盖,将做跳过处理","操作提示");                  return ;            }            $this->log( "正在努力的生成 $toFile " );            //创建目录目录!            $pInfo = pathinfo( $toFile );            $dir = $pInfo["dirname"];  if(!is_dir( $dir) ){ mkdir($dir , 0777 , 1);}            list($width, $height, $type, $attr) = getimagesize($srcImage);            if($width < $maxWidth  || $height < $maxHeight) return ;            switch ($type) {                case 1: $img = imagecreatefromgif($srcImage); break;                case 2: $img = imagecreatefromjpeg($srcImage); break;                case 3: $img = imagecreatefrompng($srcImage); break;            }            $scale = min($maxWidth/$width, $maxHeight/$height); //求出绽放比例//...........

好建议,写得太随手,已修改!
           $maxWidth = $this->_option["maxWidth"];
           $maxHeight = $this->_option["maxHeight"];
放到循环外不是更好些?

resize 方法显得很臃肿

    public function execution()    {        $maxWidth = $this->_option["maxWidth"];        $maxHeight = $this->_option["maxHeight"];       foreach( $this->srcFiles as $key =>$val ):           $srcImg = $val;           $toFile = str_replace( $this->srcDirs , $this->exportDir , $srcImg); //todo 简便处理.           $this->resize($srcImg , $toFile , $maxWidth , $maxHeight );       endforeach;    }

很不错~Mark学习一下~

技术流改变生活....等楼主放美女照片

代码收藏了,原来楼主是在深圳工作

来深圳两年了,有空一起出来,聊天吹水.
代码收藏了,原来楼主是在深圳工作

1.看你echo html 标签,这是第一个问题,这个程序理应适合用命令行执行,而不是web方式

2. if($width 
3.递归目录用RecursiveDirectoryIterator 会爽很多,手册(用户讨论版)上面就有很多例程,以你能写出这个类的本领,看看应该例程不难掌握

4.resize的算法可以更加简单,再想想吧

5.图片很多的话建议用ImageMagick而不是GD,效率更高

6."\n" "/"换成PHP_EOL和DIRECTORY_SEPARATOR常量吧,兼容一下win


最后的最后,大量图片还是用工具做缩放吧,专业软件效率高而且能控制输出的图片质量
但你的这个类修改后可以用在处理上传图片的后续处理,还是用处不小

resize 这个方法,直接来自互联网, 我并未关注里面的写法,这里也不愿意去较真,更多的是快速整合与实现!
1.看你echo html 标签,这是第一个问题,这个程序理应适合用命令行执行,而不是web方式

2. if($width 
3.递归目录用RecursiveDirectoryIterator 会爽很多,手册(用户讨论版)上面就有很多例程,以你能写出这个类的……

不要纠结效率啥的,前提是生活便利

imagick 核心三行代码完成缩略图,问题是你可能正好没imagick环境呢,或者安装了版本不匹配呢,这一折腾,我转换都快完成啦
$image = new Imagick("mypicture.png");
$image->thumbnailImage(200, 150, true);
$image->writeImage("thumb.png");

前面是凑字的,可完全忽略

我主要的意思是,LZ,你能否先放出图呢?

自己用更加要快,代码漂亮反而是次要的

不纠结上不了#30啊,看来我应该把6点分开6层楼……

呵呵,大家期待放照呢  

我是来看美女的

楼主快爆照

过来参合一下~

F5已碎

有分散都没人接?快点盖到30楼

速速上图

接分外加看美女照片 兄弟们雄起啊 就差两楼了

楼下的 兄弟们终于等到你了....

照片涅

代码真心不错,最重要的是服务生活的思想,太酷了!
貌似我是30楼啊!!
中奖了!

sorry,图片在家里的机器上,回家立马补上~

不是美女揍一顿

我只对相片感兴趣

人格担保,图片来自偷拍~




请问我是看中间这个美女的上面还是下面?

echo    '先别急嘛,伯虎兄,你要知道美女这种东西,跟鲜花一样,需要有绿叶来衬托才会显出她的娇媚,你再看看嘛';

美女看了,代码收下了!!哈哈

确实是美女,不过美女是不是穿个山寨衣服呀。 “never cry” 少个“y”?

出去走走,放松心情。周末程序员们都去拍照吧~

好东西,收藏了,谢谢!

先  mark,  日后再说

确实是美女,不过美女是不是穿个山寨衣服呀。 “never cry” 少个“y”?

哈哈 这个 可以有

46楼真相

F5已碎 呵呵,笑死我了。。。

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
과대 광고 : 오늘 PHP의 역할을 평가합니다과대 광고 : 오늘 PHP의 역할을 평가합니다Apr 12, 2025 am 12:17 AM

PHP는 현대적인 프로그래밍, 특히 웹 개발 분야에서 강력하고 널리 사용되는 도구로 남아 있습니다. 1) PHP는 사용하기 쉽고 데이터베이스와 완벽하게 통합되며 많은 개발자에게 가장 먼저 선택됩니다. 2) 동적 컨텐츠 생성 및 객체 지향 프로그래밍을 지원하여 웹 사이트를 신속하게 작성하고 유지 관리하는 데 적합합니다. 3) 데이터베이스 쿼리를 캐싱하고 최적화함으로써 PHP의 성능을 향상시킬 수 있으며, 광범위한 커뮤니티와 풍부한 생태계는 오늘날의 기술 스택에 여전히 중요합니다.

PHP의 약한 참고 자료는 무엇이며 언제 유용합니까?PHP의 약한 참고 자료는 무엇이며 언제 유용합니까?Apr 12, 2025 am 12:13 AM

PHP에서는 약한 참조가 약한 회의 클래스를 통해 구현되며 쓰레기 수집가가 물체를 되 찾는 것을 방해하지 않습니다. 약한 참조는 캐싱 시스템 및 이벤트 리스너와 같은 시나리오에 적합합니다. 물체의 생존을 보장 할 수 없으며 쓰레기 수집이 지연 될 수 있음에 주목해야합니다.

PHP의 __invoke 마법 방법을 설명하십시오.PHP의 __invoke 마법 방법을 설명하십시오.Apr 12, 2025 am 12:07 AM

\ _ \ _ 호출 메소드를 사용하면 객체를 함수처럼 호출 할 수 있습니다. 1. 객체를 호출 할 수 있도록 메소드를 호출하는 \ _ \ _ 정의하십시오. 2. $ obj (...) 구문을 사용할 때 PHP는 \ _ \ _ invoke 메소드를 실행합니다. 3. 로깅 및 계산기, 코드 유연성 및 가독성 향상과 같은 시나리오에 적합합니다.

동시성에 대해 PHP 8.1의 섬유를 설명하십시오.동시성에 대해 PHP 8.1의 섬유를 설명하십시오.Apr 12, 2025 am 12:05 AM

섬유는 PHP8.1에 도입되어 동시 처리 기능을 향상시켰다. 1) 섬유는 코 루틴과 유사한 가벼운 동시성 모델입니다. 2) 개발자는 작업의 실행 흐름을 수동으로 제어 할 수 있으며 I/O 집약적 작업을 처리하는 데 적합합니다. 3) 섬유를 사용하면보다 효율적이고 반응이 좋은 코드를 작성할 수 있습니다.

PHP 커뮤니티 : 자원, 지원 및 개발PHP 커뮤니티 : 자원, 지원 및 개발Apr 12, 2025 am 12:04 AM

PHP 커뮤니티는 개발자 성장을 돕기 위해 풍부한 자원과 지원을 제공합니다. 1) 자료에는 공식 문서, 튜토리얼, 블로그 및 Laravel 및 Symfony와 같은 오픈 소스 프로젝트가 포함됩니다. 2) 지원은 StackoverFlow, Reddit 및 Slack 채널을 통해 얻을 수 있습니다. 3) RFC에 따라 개발 동향을 배울 수 있습니다. 4) 적극적인 참여, 코드에 대한 기여 및 학습 공유를 통해 커뮤니티에 통합 될 수 있습니다.

PHP vs. Python : 차이점 이해PHP vs. Python : 차이점 이해Apr 11, 2025 am 12:15 AM

PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.

PHP : 죽어 가거나 단순히 적응하고 있습니까?PHP : 죽어 가거나 단순히 적응하고 있습니까?Apr 11, 2025 am 12:13 AM

PHP는 죽지 않고 끊임없이 적응하고 진화합니다. 1) PHP는 1994 년부터 새로운 기술 트렌드에 적응하기 위해 여러 버전 반복을 겪었습니다. 2) 현재 전자 상거래, 컨텐츠 관리 시스템 및 기타 분야에서 널리 사용됩니다. 3) PHP8은 성능과 현대화를 개선하기 위해 JIT 컴파일러 및 기타 기능을 소개합니다. 4) Opcache를 사용하고 PSR-12 표준을 따라 성능 및 코드 품질을 최적화하십시오.

PHP의 미래 : 적응 및 혁신PHP의 미래 : 적응 및 혁신Apr 11, 2025 am 12:01 AM

PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경