Joyber 发布的文章

使用PHPExcel库导出excel文件代码,Yii1.1框架下编写,相关代码需要自行调整


    /**
     * @param string $filepath
     * @param array $titles
     * @param int $startRow
     * @return array|false
     */
    public static function importExcelData($filepath, $titles, int $startRow)
    {
        $datas = [];
        try {
            Yii::import('application.vendors.phpexcel.*');
            require_once 'PHPExcel.php';

            //读取文件
            $objReader   = PHPExcel_IOFactory::createReader('Excel2007');
            $objPHPExcel = $objReader->load($filepath);
            //读取表格数据存入$datas
            $objPHPExcel->setActiveSheetIndex(0);
            $sheet      = $objPHPExcel->getSheet(0);
            $highestRow = $sheet->getHighestDataRow();
            $letters    = range('A', 'Z');
            $columns    = array_keys($titles);
            for ($row = $startRow; $row <= $highestRow; $row++) {
                $_data = [];
                foreach ($columns as $k => $key) {
                    $_data[$key] = $sheet->getCell("{$letters[$k]}{$row}")->getValue();
                }
                $datas[] = $_data;
            }
            return $datas;
        } catch (\Exception $e) {
            return false;
        }
    }

    /**
     * 导出Excel文件
     * @param $titles
     * @param $data
     * @param $filename
     * @return void
     * @throws CException
     */
    public static function exportExcel($titles, $data, $filename)
    {

        Yii::import('application.vendors.phpexcel.*');
        require_once 'PHPExcel.php';

        $objPHPExcel = new PHPExcel();
        try {
            //生成A到AZ的列名称数组
            $cols = range('A', 'Z');
            array_push($cols, ...array_map(function ($v) {
                return "A{$v}";
            }, $cols));
            $objSheet = $objPHPExcel->getActiveSheet();
            //工作表标题
            $objSheet->setTitle("外呼结果");
            $rowIdx = 1;
            $titleArr = array_values($titles);
            //第一行内容,放列标题
            foreach ($titleArr as $k=>$title) {
                $objSheet->setCellValue($cols[$k] . $rowIdx, $title);
            }
            //设置第一行的背景颜色
            $objSheet->getStyle("A{$rowIdx}:{$cols[$k]}1")
                ->getFill()
                ->setFillType(PHPExcel_Style_Fill::FILL_SOLID)
                ->getStartColor()
                ->setRGB('E8E8E8');
            //后面行循环放内容
            foreach ($data as $row) {
                $rowIdx++;
                foreach ($titleArr as $k=>$title) {
                    //如果值长度超过阈值,则只保存为字符型单元格格式,避免长数字显示为科学计数法
                    $value = $row[$k]??'';
                    if (is_numeric($value) && mb_strlen($value, 'UTF-8') > 10) {
                        $objSheet->setCellValueExplicit($cols[$k] . $rowIdx, $value);
                    } else {
                        $objSheet->setCellValue($cols[$k] . $rowIdx, $value);
                    }
                }
            }

            // Rename worksheet
            // Set active sheet index to the first sheet, so Excel opens this as the first sheet
            $objPHPExcel->setActiveSheetIndex(0);
            // Redirect output to a client’s web browser (Excel2007)
            header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
            header('Content-Disposition: attachment;filename="' . $filename . '.xlsx"');
            header('Cache-Control: max-age=0');
            // If you're serving to IE 9, then the following may be needed
            header('Cache-Control: max-age=1');
            // If you're serving to IE over SSL, then the following may be needed
            header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
            header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
            header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
            header('Pragma: public'); // HTTP/1.0
            $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
            $objWriter->save('php://output');
        } catch (\PHPExcel_Exception $e) {
            $line = __LINE__;
            $file = __FILE__;
            zmf::fp("导出文件 {$filename} 出错:{$e->getMessage()}:({$line}){$file},args:".CJSON::encode(func_get_args()));
            Yii::app()->controller->message(200, '导出文件出错');
        }
    }

css去掉input type=“number”的上下箭头

// css去掉input type=“number”的上下箭头
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
}
.member-form,.rpo-form input[type="number"] {
  -moz-appearance: textfield;
}

千位分隔符

千位分隔符,其实就是数字中的逗号。依西方的习惯,人们在数字中加进一个符号,以免因数字位数太多而难以看出它的值。所以人们在数字中,每隔三位数加进一个逗号,也就是千位分隔符,以便更加容易认出数值。
举个

1000 ---> 1,000 千
1000000 ---> 1,000,000 百万
100000000 ---> 100,000,000 亿

方法1

将数字转为字符串,将小数部分与整数部分分离
整数部分分隔为数组,并且反转
反转后的数组每隔3位添加,
添加完成后,再反转回来,拼接小数部分,完成格式化

function thousandsSeparator(n: number): string {
  const strSplit = n.toString().split(".");
  const integer = strSplit[0].split("");
  integer.reverse();
  const decimal = strSplit[1];
  const newInteger = [];
  for (let i = 0; i < integer.length; i++) {
    if (i % 3 === 0 && i !== 0) {
      newInteger.push(",");
    }
    newInteger.push(integer[i]);
  }
  newInteger.reverse();
  let s = newInteger.join("");
  if (decimal) {
    s += `.${decimal}`;
  }
  return s;
}

方法2
使用JS原生API toLocaleString 。
这是数字类型原型上一个方法(# Number.prototype.toLocaleString), 它的作用就是返回数字在特定语言环境下表示的字符串.作用很强大,兼容性也很好,详细的介绍小伙伴可以去点击连接。

const number = 123456.789;
number.toLocaleString(); // => '123,456.789'

方法3
使用JS原生API Intl.NumberFormat
Intl.NumberFormat对象启用对语言敏感的数字格式

const number = 3500;
console.log(new Intl.NumberFormat().format(number)); // → '3,500'

方法4
使用正则表达匹配的方式

function thousandsSeparator2(n: number): string {
  const strSplit = n.toString().split(".");
  const integer = strSplit[0];
  const decimal = strSplit[1] || "";
  return integer.replace(/\B(?=(\d{3})+(?!\d))/g, ",") + decimal;
}

#! /bin/bash
echo -e "更新工作号消费数据录入:"
read -p "开始日期(如:2024-11-01):" startDate
read -p "结束日期(如:2024-11-27):" endDate

if [ $startDate != '' -a $endDate != '' ] ;then
        cmdLine="/web/tell/protected/yiic adr updateAgUdataLimitDate --startDate=${startDate} --endDate=${endDate}"
    read -p "run: ${cmdLine} ?(Yes/No):" ok
    case "$ok" in
        Yes|yes|y|Y)
            eval "${cmdLine}"    
        ;;
        No|no|n|N)
            echo -e "取消执行"
        ;;
        *)
    esac
else
    echo '请指定:开始和结束日期'
fi;