Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > PHP > PHP Forum > PHPExcel addsheets แล้ว write ใน sheets อื่นยังไงอะครับ



 

PHPExcel addsheets แล้ว write ใน sheets อื่นยังไงอะครับ

 



Topic : 128699



โพสกระทู้ ( 7 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook



Code (PHP)
$objPHPExcel = new PHPExcel();
$objPHPExcelAll = new PHPExcel();
$strPath = realpath(basename(getenv($_SERVER["SCRIPT_NAME"])));
$count_info3 = $db->count_info("3");  // คิวรี่ นัมโรว มาจาก db

// อันที่เขียนลง sheets หลัก โดยการ get data งานทั้งหมดมาสรุปรวมในชีทนี้ + โคลนชีท
$objPHPExcelAll->setActiveSheetIndex(0);
$newSheet = clone $objPHPExcelAll->getActiveSheet();

	$row = 2;
	$dirs = array_filter(glob('project_data/26-04-60/*'), 'is_dir');
	$dirCount = count($dirs);
	for($r = 0; $r < $dirCount; $r++){
		$folderName = substr($dirs[$r], strrpos($dirs[$r], "/") + 1);
		$data = $db->get_data(3, "26-04-60", $folderName);
		
		$c = 1;
		$column = 'A';
		while($c <= $count_info3){
			$objPHPExcelAll->getActiveSheet()->setCellValue($column . $row, $data[$c - 1]);
			
			$c++;
			$column++;
		}
		$row++;	
	}

// โคลนเสดละ ทีนี้ addsheets 
	$newSheet->setTitle('Sheets2');
	$objPHPExcelAll->addSheet($newSheet);

// จบด้วย save file ครับ
	$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcelAll, 'Excel2007');
	$strFileName = $directoryAll."3.0.xlsx";
	$objWriter->save($strPath."/".$strFileName);
	$db->reset_template($count_info3,$objPHPExcel);




เลยสงสัยว่า จะเขียนลงไปใน sheets2 ยังไงอะครับ ลูป data ก็ไม่เข้า เขียนตรงๆก็ไม่เข้า มันมาเข้าใน sheets หลักหมดเลย



Tag : PHP, MySQL, Excel (Excel.Application), Share Hosting, Bootstrap Framework, Windows









ประวัติการแก้ไข
2017-08-25 11:15:39
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2017-08-25 10:58:13 By : 1676148892398444 View : 2548 Reply : 3
 

 

No. 1



โพสกระทู้ ( 9,586 )
บทความ ( 2 )



สถานะออฟไลน์


set active sheet ใหม่ ก่อน write ชีทใหม่
$objPHPExcelAll->setActiveSheetIndex(1);






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-08-25 11:20:22 By : Chaidhanan
 


 

No. 2



โพสกระทู้ ( 7 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

ตอบความคิดเห็นที่ : 1 เขียนโดย : Chaidhanan เมื่อวันที่ 2017-08-25 11:20:22
รายละเอียดของการตอบ ::
... ใช่แล้วครับเซ็ทชีทตรงก่อน write sheets ใหม่ ขอบคุณมากๆเลยครับ
ว่าแต่ทำไมใส่ข้างล่าง $objPHPExcelAll->setActiveSheetIndex(0); ไม่ได้อะนิ T_T

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-08-25 11:28:51 By : 1676148892398444
 

 

No. 3



โพสกระทู้ ( 9,586 )
บทความ ( 2 )



สถานะออฟไลน์


ทำเป็นตัวอย่าง
Book1.xlsx Sheet1:cell(A1)='TEST' สร้างเอาหน่อย ลองเอาเอง จะได้เห็น
Code (PHP)
<?php
$nfile='CloneAdd.xlsx';
if(is_file($nfile)) unlink($nfile);
require_once 'ClassExcel/PHPExcel.php';
include 'ClassExcel/PHPExcel/IOFactory.php';
$inputFileName = 'Book1.xlsx';
$inputFileType = PHPExcel_IOFactory::identify($inputFileName);  
$Reader = PHPExcel_IOFactory::createReader($inputFileType);  
$SheetS = $Reader->load($inputFileName);  
$SheetS->setActiveSheetIndex(0);

$newSheet = clone $SheetS->getActiveSheet();
$newSheet->setTitle('Test2');
$SheetS->addSheet($newSheet);
///
	// จะทำอะไรกับชีทใหม่ก็ใส่ตรงนี้
	$newSheet->SetCellValue('B1', 'add new');
///
$Write = PHPExcel_IOFactory::createWriter($SheetS, 'Excel2007');
$Write->save($nfile);


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-08-25 13:40:47 By : Chaidhanan
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : PHPExcel addsheets แล้ว write ใน sheets อื่นยังไงอะครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 03
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่