php 脚本进度条

<?php
/**
 * 生产修复数据的时候,写啦一个脚本找运维执行,时间太长运维叨叨说脚本也没有个进度条,什么时候能执行完成都不知道
 * 最后修复完成回来写的玩的
 */


$totalLen = 50;       //默认进度条的长度
$dataCount = 1;      //默认的执行次数,(需要处理的数据条数)
$baseNum = 100;        //百分比进制


for ($i = 1; $i <= $dataCount; $i++) {

    $ratio = bcmul(bcdiv($i, $dataCount, 2), $baseNum);                       //计算当前执行位置在总循环次数的占比
    $speedLen = ceil(bcmul($totalLen, bcdiv($ratio, $baseNum, 2)));           //然后乘以总长度得出当前进度条显示长度
    $spaceLen = $totalLen - $speedLen;                                               // 获取剩余未完成长度


    sleep(1);                                                               //这是相当于处理的程序


    echo '[' . str_repeat('#', $speedLen) . str_repeat(' ', $spaceLen) . ']' . $ratio . '%' . "\r";
    if ($ratio == $baseNum) {
        writeLog(['count' => $dataCount, 'msg' => '历史数据修复问题完成']);
    }
}

//记录日志的方法
function writeLog($data)
{
    if (is_array($data)) {
        $data = json_encode($data,JSON_UNESCAPED_UNICODE);                       //1 file_put_contents()只能保存一维数组和字符串,所以要转json格式  2 JSON_UNESCAPED_UNICODE 中文不转义
    }
    $msg = date("Y-m-d H:i:s", time()) . ' | ' . microtime() . '|' . $data . PHP_EOL;                 // PHP_EOL php兼容linux,os,win 的换行的问题方法
    $fileName = 'logs' . '/local-' . date("Y-m-d", time()) . '.log';                //首先创建logs文件夹,不然保存不上
    file_put_contents($fileName, $msg,FILE_APPEND | LOCK_EX);                       //FILE_APPEND添加数据为追加形式,LOCK_EX设置独占锁
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值