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 > .NET Framework > Forum > .NET (Copy Sheet) แยก sheet หลายๆๆ Sheet ใน ไฟร์ excel ออกเป็น ไฟร์ excel ในแต่ละ sheet ครับ



 

.NET (Copy Sheet) แยก sheet หลายๆๆ Sheet ใน ไฟร์ excel ออกเป็น ไฟร์ excel ในแต่ละ sheet ครับ

 



Topic : 065058



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



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




พี่พอจะมีตัวอย่างการ copy Sheet ใน ไฟร์ excel เอาไปสร้างเป็น ไฟร์ excel ใหม่มั้ยครับ
คือว่า ใน excel ต้นฉบับ มันมีอยู่หลายๆๆ sheet แต่ จะแยกมันให้ แต่ละ sheet สรา้งเป็ฯ 1 ไฟร์ excel
พอมีตัวอย่างมั้ยครับ คือผมเจ็น excel ได้แต่ว่า ผมไม่สามารถ ก๊อบปี้ แต่ละ sheet ลงไปได้ครับรบกวนหน่อยนะครับ

เป็ฯ windows app และใช้ C# เขียนครับ



Tag : .NET, Win (Windows App), C#







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2011-08-20 15:58:40 By : pacus View : 6807 Reply : 5
 

 

No. 1



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



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


อันนี้เป็ฯโคสที่ผมลองทำดูคับ แต่มันก็ขึ้น error

Code (C#)
            ApplicationClass ExcelApp;
            Workbook ExcelBooks;
            Worksheet ExcelSheets;
            Worksheet worksheet;
            Thread CurrentThread;

            ExcelApp = new ApplicationClass();

            CurrentThread = Thread.CurrentThread;
            CurrentThread.CurrentCulture = new CultureInfo("en-US");

            String FileName = @"D:\MyExcel.xls";


            try
            {
                FileInfo MyFile = new FileInfo(FileName);
                if (MyFile.Exists)
                {
                    MyFile.Delete();
                }

                ExcelApp = new ApplicationClass();

                CurrentThread = Thread.CurrentThread;
                CurrentThread.CurrentCulture = new CultureInfo("en-US");


                ExcelApp.Visible = true;
                ExcelBooks = ExcelApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet);
               
                Worksheet     worksheet = ((Worksheet)dtCustommail.Rows[0]["File"]);
                newWorksheet = (Worksheet)ExcelBooks.Worksheets.Add(Type.Missing, Type.Missing, Type.Missing,Type.Missing);
             newWorksheet.Copy(Type.Missing, worksheet);
                
                   
                ExcelBooks.SaveAs(FileName, XlFileFormat.xlXMLSpreadsheet, Type.Missing, Type.Missing,
                false, false, XlSaveAsAccessMode.xlNoChange,
                Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);







แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2011-08-20 16:31:28 By : pacus
 


 

No. 2



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

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

Code (PHP)
<?
	$objExcel = new COM("Excel.Application");
	$objWorkbook = $objExcel->Workbooks->Open("C:\Scripts\testsheet.xls");
	$objExcel->Visible = true;

	$objLastSheet = $objWorkbook->Worksheets("Sheet3");
	$objWorksheet = $objWorkbook->Worksheets("Sheet1");
	$objWorksheet->Copy($objLastSheet);

	$objWorksheet = $objWorkbook->Worksheets("Sheet1 (2)");
	$objWorksheet->Name = "My New Worksheet";
?>


อันนี้เป็น php น่าจะเป็นแนวทางได้ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2011-08-20 17:40:40 By : webmaster
 

 

No. 3



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

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

หาเจอพอดีครับ ไม่ต่างอะไรกับ php ครับ

Code (C#)
   string src = @"Book1.xlsx";
    string dst = @"Book2.xlsx";

    object missing = Missing.Value;

    ApplicationClass app = new ApplicationClass();
    WorkbookClass wb1 = (WorkbookClass) app.Workbooks.Open(src, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing,missing);
    WorkbookClass wb2 = (WorkbookClass)app.Workbooks.Open(dst, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing);

    Worksheet sheet1 = (Worksheet) wb1.Worksheets["Sheet1"];
    Worksheet sheet2 = (Worksheet)wb2.Worksheets["Sheet1"];
    try
    {
        sheet1.Copy(sheet2,missing );
    }catch (Exception ex){
        //
    }
    finally{
        app.Quit();
    }



Code (VB.NET)
Dim src As String = "Book1.xlsx"
Dim dst As String = "Book2.xlsx"

Dim missing__1 As Object = Missing.Value

Dim app As New ApplicationClass()
Dim wb1 As WorkbookClass = DirectCast(app.Workbooks.Open(src, missing__1, missing__1, missing__1, missing__1, missing__1, _
	missing__1, missing__1, missing__1, missing__1, missing__1, missing__1, _
	missing__1, missing__1, missing__1), WorkbookClass)
Dim wb2 As WorkbookClass = DirectCast(app.Workbooks.Open(dst, missing__1, missing__1, missing__1, missing__1, missing__1, _
	missing__1, missing__1, missing__1, missing__1, missing__1, missing__1, _
	missing__1, missing__1, missing__1), WorkbookClass)

Dim sheet1 As Worksheet = DirectCast(wb1.Worksheets("Sheet1"), Worksheet)
Dim sheet2 As Worksheet = DirectCast(wb2.Worksheets("Sheet1"), Worksheet)
Try
	sheet1.Copy(sheet2, missing__1)
		'
Catch ex As Exception
Finally
	app.Quit()
End Try

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2011-08-20 17:41:43 By : webmaster
 


 

No. 4

Guest


แล้ว ถ้าเป็น JAVA ล่ะคะ
ทำได้มั้ย
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-05-17 17:56:43 By : Kwang
 


 

No. 5



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

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

ตอบความคิดเห็นที่ : 4 เขียนโดย : Kwang เมื่อวันที่ 2012-05-17 17:56:43
รายละเอียดของการตอบ ::
ผมไม่มี Code ตัวนี้สำหรับ Java ครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-05-21 20:13:50 By : mr.win
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : .NET (Copy Sheet) แยก sheet หลายๆๆ Sheet ใน ไฟร์ excel ออกเป็น ไฟร์ excel ในแต่ละ sheet ครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 04
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 อัตราราคา คลิกที่นี่