phpexcel匯出excel的顏色與網頁中顏色不一致的解決方案

來源:互聯網
上載者:User
  1. require_once './PHPExcel.php';
  2. require_once './Excel5.php';
  3. require_once './get_excel_row.php';
  4. require "../include/base.php";
  5. require "../include/function/006/creatExcelDb.php";
  6. define("COLOR1","#96B7F6");
  7. //查 處理 資料--------------------------
  8. $q = $db->query("select * from oa_event_sales");
  9. while($a = $db->fetch_array($q)){
  10. $list[] = $a;
  11. }
  12. $ce = new creatExcelDb();
  13. $re = $ce->_run($list,'served_time','client_status','oid');
  14. $all_nums=0;
  15. $num=array();
  16. foreach($re as $k=>$v){
  17. $num[$k]=count($re[$k]);
  18. $all_nums+=count($re[$k]);
  19. }
  20. $jq = array();
  21. $title1 = client_status;
  22. $title2 = fin_confirm;
  23. $title3 = oid;
  24. //去除數組中相同的值
  25. foreach($re as $key => $val){
  26. if(true){
  27. foreach($val as $key2 => $val2){
  28. if(!in_array($key2,$jq)){
  29. $jq[] = $key2;
  30. }
  31. }
  32. }
  33. }
  34. $arr_keys=array();
  35. foreach($re as $k=>$v){
  36. foreach($v as $k2=>$v2){
  37. $arr_keys[]=$k2;
  38. }
  39. }
  40. $c=array_count_values($arr_keys);
  41. //++===---------------------------
  42. // 建立一個處理對象執行個體
  43. $objExcel = new PHPExcel();
  44. // 建立檔案格式寫入對象執行個體, uncomment
  45. $objWriter = new PHPExcel_Writer_Excel5($objExcel);
  46. //設定文檔基本屬性/**似乎一般情況下用不到**/
  47. $objProps = $objExcel->getProperties();
  48. $objProps->setCreator("楊本木");
  49. $objProps->setLastModifiedBy("楊本木");
  50. $objProps->setTitle("楊本木");
  51. $objProps->setSubject("楊本木");
  52. $objProps->setDescription("楊本木");
  53. $objProps->setKeywords("楊本木");
  54. $objProps->setCategory("楊本木");
  55. //*************************************
  56. //設定當前的sheet索引,用於後續的內容操作。
  57. //一般只有在使用多個sheet的時候才需要顯示調用。
  58. //預設情況下,PHPExcel會自動建立第一個sheet被設定SheetIndex=0
  59. $objExcel->setActiveSheetIndex(0);
  60. $objActSheet = $objExcel->getActiveSheet();
  61. //設定當前活動sheet的名稱
  62. $objActSheet->setTitle('當前sheetname');
  63. //設定寬度,這個值和EXCEL裡的不同,不知道是什麼單位,略小於EXCEL中的寬度
  64. //$objActSheet->getColumnDimension('A')->setWidth(20);
  65. //$objActSheet->getRowDimension(1)->setRowHeight(30); //高度
  66. //設定儲存格的值
  67. $objActSheet->setCellValue('A1', '總標題顯示');
  68. /*
  69. //設定樣式
  70. $objStyleA1 = $objActSheet->getStyle('A1');
  71. $objStyleA1->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  72. $objFontA1 = $objStyleA1->getFont();
  73. $objFontA1->setName('宋體');
  74. $objFontA1->setSize(18);
  75. $objFontA1->setBold(true);
  76. //設定列置中對齊
  77. $objActSheet->getStyle('D')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  78. */
  79. //---------------first---------------------
  80. $benmu=1;
  81. $objActSheet->setCellValue('A1', '列標籤\欄標籤');
  82. foreach($jq as $k=>$v){
  83. $objActSheet->setCellValue(get_excel_row($benmu).'1', $v);
  84. $benmu+=1;
  85. }
  86. $objActSheet->setCellValue(get_excel_row($benmu).'1', '總計');
  87. //設定寬度
  88. for($i=0;$i<$benmu+1;$i++){
  89. $objActSheet->getColumnDimension(get_excel_row($i))->setWidth(20);
  90. //寬度
  91. $objActSheet->getStyle(get_excel_row($i)."1")->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  92. $objActSheet->getStyle(get_excel_row($i))->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  93. //顏色
  94. $objActSheet->getStyle(get_excel_row($i)."1")->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
  95. $objActSheet->getStyle(get_excel_row($i)."1")->getFill()->getStartColor()->setARGB(COLOR1);
  96. }
  97. //-------------content--------------------
  98. $y=2;
  99. foreach($re as $k1=>$v1){ //$k1全部放在A2。。。。後面,k1為電話號碼、v1為person-》數字
  100. $objActSheet->setCellValue('A'.$y, $k1);
  101. //顏色
  102. $objActSheet->getStyle('A'.$y)->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
  103. $objActSheet->getStyle('A'.$y)->getFill()->getStartColor()->setARGB(COLOR1);
  104. foreach($jq as $k2=>$v2){ //k2是0,v2是person
  105. foreach($v1 as $k3=>$v3){ //$k3為person,$v3是要的值
  106. if($k3==$v2){
  107. //$objActSheet->setCellValue(get_excel_row("1"+$k2).$y,$v1[$k3]);
  108. $objActSheet->setCellValueExplicit(get_excel_row("1"+$k2).$y,$v1[$k3],PHPExcel_Cell_DataType::TYPE_STRING);
  109. }
  110. }
  111. }
  112. $objActSheet->setCellValue(get_excel_row("1"+count($jq)).$y, $num[$k1]);
  113. $y+=1;
  114. }
  115. //-----------------last----------------
  116. $objActSheet->setCellValue("A".$y,"總計");
  117. //顏色
  118. $objActSheet->getStyle("A".$y)->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
  119. $objActSheet->getStyle("A".$y)->getFill()->getStartColor()->setARGB(COLOR1);
  120. foreach($jq as $k=>$v){ //k為person
  121. $objActSheet->setCellValue(get_excel_row("1"+$k).$y,$c[$v]);
  122. //顏色
  123. $objActSheet->getStyle(get_excel_row("1"+$k).$y)->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
  124. $objActSheet->getStyle(get_excel_row("1"+$k).$y)->getFill()->getStartColor()->setARGB(COLOR1);
  125. }
  126. $objActSheet->setCellValue(get_excel_row("1"+count($jq)).$y,$all_nums);
  127. //顏色
  128. $objActSheet->getStyle(get_excel_row("1"+count($jq)).$y)->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
  129. $objActSheet->getStyle(get_excel_row("1"+count($jq)).$y)->getFill()->getStartColor()->setARGB(COLOR1);
  130. //-----------------------------------
  131. //輸出內容
  132. $outputFileName =time().".xls";
  133. header("Pragma: public");
  134. header("Expires: 0");
  135. header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
  136. header("Content-Type:application/force-download");
  137. header("Content-Type:application/octet-stream");
  138. header("Content-Type:application/download");
  139. header('Content-Disposition:attachment;filename='.$outputFileName.'');
  140. header("Content-Transfer-Encoding:binary");
  141. $objWriter->save('php://output');
  142. ?>
複製代碼

以上的代碼,define中的顏色在匯出的excel沒有正確顯示出本來應該的顏色。開始定義了一個紅色看顯示是什麼,如下:define(“COLOR1″,”#FF0000″);但是結果顯示的是,定義藍色在excel中顯示為類似於紫色的顏色,反正就不是頁面顯示的那種顏色。看這句代碼:$objActSheet->getStyle(‘A'.$y)->getFill()->getStartColor()->setARGB(COLOR1);考慮可能是ARGB的原因,試著把顏色前面加兩位00,格式可能是這樣的argb(128,255,0,0),可以先排除這個問題,因為a是透明度,實驗後才知道,確實是增加了透明度的4位定色。

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.