|
data:image/s3,"s3://crabby-images/9df89/9df89c83e8c1e31438585f2c965544b2676fc113" alt="" |
|
สอบถาม Code VB.net ที่ใช้ Export ข้อมูลจาก SQL เป็นไฟล์ Excel แบบ 1 ไฟล์ Excel มีหลาย WorkSheet ค่ะ |
|
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
โดยปกติผมทำดึงแค่ Sheet เดียวหลาย ๆ Sheet ไม่เคย ตามนี้เลย
Code (VB.NET)
Private Sub excelHexa()
If MessageBox.Show("ต้องการออกรายงานข้อมูล หรือไม่", "ยืนยันการออกรายงาน", MessageBoxButtons.YesNo, MessageBoxIcon.Warning) = DialogResult.Yes Then
Dim excel8 As New Excel.Application
Dim cu As System.Threading.Thread
cu = System.Threading.Thread.CurrentThread
cu.CurrentUICulture = New CultureInfo("en-US")
System.Threading.Thread.CurrentThread.CurrentCulture = System.Globalization.CultureInfo.CreateSpecificCulture("en-US")
excelapp.Visible = True
excelbooks = excelapp.Workbooks.Add
excelsheets = CType(excelbooks.Worksheets(1), Excel.Worksheet)
Try
With excelsheets
Dim A As Integer
For A = 1 To 1
.Range("A1:J10").Font.Name = "Tahoma"
.Range("A" & A.ToString & ":J" & A.ToString).Merge()
With .Range("A1:J1")
.Font.Bold = True
.Font.Underline = True
.Value = "บริษัท .... รวมทุนจำกัด จำกัด"
.Font.Size = 18
.HorizontalAlignment = Excel.XlHAlign.xlHAlignCenter
End With
Next
Dim H As Integer
For H = 2 To 2
.Range("A" & H.ToString & ":J" & H.ToString).Merge()
.Range("A" & H.ToString & ":J" & H.ToString).HorizontalAlignment = Excel.XlHAlign.xlHAlignCenter
With .Range("A2:J2")
.Font.Bold = True
.Value = "ใบแสดงรายงานเกี่ยวกับรายการ SCAN FINGER (สแกนนิ้วมือ) แบบรายวัน / รายบุคคล"
.Font.Size = 14
End With
Next
Dim G As Integer
For G = 3 To 3
.Range("A" & G.ToString & ":J" & G.ToString).Merge()
.Range("A" & G.ToString & ":J" & G.ToString).HorizontalAlignment = Excel.XlHAlign.xlHAlignRight
With .Range("A3:J3")
' Dim Buttoms As String = ""
.Value = " พิมพ์รายงาน ณ วันที่ " & Today.ToShortDateString()
.Font.Size = 10
End With
Next
.Range("A4:K35").Font.Name = "Tahoma"
.Columns().ColumnWidth = 15
.Range("A4").Value = "ลำดับ"
.Range("A4").Font.Size = 10
.Range("A4").Font.Color = RGB(255, 255, 255)
.Range("A4").Interior.Color = RGB(255, 69, 28)
.Range("B4").Value = "รหัสพนักงาน"
.Range("B4").Font.Size = 10
.Range("B4").Font.Color = RGB(255, 255, 255)
.Range("B4").Interior.Color = RGB(255, 69, 28)
.Range("C4").Value = "วัน"
.Range("C4").Font.Size = 10
.Range("C4").Font.Color = RGB(255, 255, 255)
.Range("C4").Interior.Color = RGB(255, 69, 28)
.Range("D4").Value = "เข้างาน"
.Range("D4").Font.Size = 10
.Range("D4").Font.Color = RGB(255, 255, 255)
.Range("D4").Interior.Color = RGB(255, 69, 28)
.Range("E4").Value = "ออกงาน"
.Range("E4").Font.Size = 10
.Range("E4").Font.Color = RGB(255, 255, 255)
.Range("E4").Interior.Color = RGB(255, 69, 28)
.Range("F4").Value = "เวลาเข้างาน"
.Range("F4").Font.Size = 10
.Range("F4").Font.Color = RGB(255, 255, 255)
.Range("F4").Interior.Color = RGB(255, 69, 28)
.Range("G4").Value = "เวลาออกงาน"
.Range("G4").Font.Size = 10
.Range("G4").Font.Color = RGB(255, 255, 255)
.Range("G4").Interior.Color = RGB(255, 69, 28)
.Range("H4").Value = "หมายเหตุ"
.Range("H4").Font.Size = 10
.Range("H4").Font.Color = RGB(255, 255, 255)
.Range("H4").Interior.Color = RGB(255, 69, 28)
.Range("I4").Value = "คำนำหน้านาม"
.Range("I4").Font.Size = 10
.Range("I4").Font.Color = RGB(255, 255, 255)
.Range("I4").Interior.Color = RGB(255, 69, 28)
.Range("J4").Value = "ชื่อพนักงาน"
.Range("J4").Font.Size = 10
.Range("J4").Font.Color = RGB(255, 255, 255)
.Range("J4").Interior.Color = RGB(255, 69, 28)
.Range("K4").Value = "นามสกุล"
.Range("K4").Font.Size = 10
.Range("K4").Font.Color = RGB(255, 255, 255)
.Range("K4").Interior.Color = RGB(255, 69, 28)
'--------------------------------------------------------------------------------------
Dim CountDate(DateDiff(DateInterval.Day, dtpTimeIn.Value, dtpTimeout.Value)) As Date
Dim n As Integer, i As Integer = 0, j As Integer = 4, v As Byte = 0
For n = 0 To DateDiff(DateInterval.Day, dtpTimeIn.Value, dtpTimeout.Value)
CountDate(n) = DateAdd(DateInterval.Day, n, dtpTimeIn.Value)
v = 0
'On Error Resume Next
'For j = 5 To (5 + (DataGridView2.RowCount - 1))
For i = 0 To DataGridView2.Rows.Count - 1
If CountDate(n).Date.ToString("dd-MM-yyyy") = CDate(DataGridView2.Rows(i).Cells("TimeIn").Value).ToString("dd-MM-yyyy") Then
v = 1
j += 1
.Range("A" & j.ToString()).Value = DataGridView2.Rows(i).Cells("ID").Value.ToString
.Range("A" & j.ToString()).Font.Size = 10
.Range("A" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("B" & j.ToString()).Value = DataGridView2.Rows(i).Cells("ID_Emp").Value.ToString
.Range("B" & j.ToString()).Font.Size = 10
.Range("B" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("C" & j.ToString()).Value = CDate(DataGridView2.Rows(i).Cells("TimeIn").Value).ToString("dddd")
.Range("C" & j.ToString()).Font.Size = 10
.Range("C" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("D" & j.ToString()).Value = DataGridView2.Rows(i).Cells("TimeIn").Value.ToString
.Range("D" & j.ToString()).Font.Size = 10
.Range("D" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("E" & j.ToString()).Value = DataGridView2.Rows(i).Cells("TimeOut").Value.ToString
.Range("E" & j.ToString()).Font.Size = 10
.Range("E" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("F" & j.ToString()).Value = DataGridView2.Rows(i).Cells("timeworkIn").Value.ToString
.Range("F" & j.ToString()).Font.Size = 10
.Range("F" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("G" & j.ToString()).Value = DataGridView2.Rows(i).Cells("timeworkOut").Value.ToString
.Range("G" & j.ToString()).Font.Size = 10
.Range("G" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("H" & j.ToString()).Value = DataGridView2.Rows(i).Cells("comment").Value.ToString
.Range("H" & j.ToString()).Font.Size = 10
.Range("H" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("I" & j.ToString()).Value = DataGridView2.Rows(i).Cells("Antacedent").Value.ToString
.Range("I" & j.ToString()).Font.Size = 10
.Range("I" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("J" & j.ToString()).Value = DataGridView2.Rows(i).Cells("Name").Value.ToString
.Range("J" & j.ToString()).Font.Size = 10
.Range("J" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("K" & j.ToString()).Value = DataGridView2.Rows(i).Cells("Surname").Value.ToString
.Range("K" & j.ToString()).Font.Size = 10
.Range("K" & j.ToString()).Font.Color = RGB(34, 54, 34)
End If
Next
If v = 0 Then
j += 1
.Range("C" & j.ToString()).Value = CountDate(n).ToString("dddd")
.Range("C" & j.ToString()).Font.Size = 10
.Range("C" & j.ToString()).Font.Color = RGB(34, 54, 34)
.Range("D" & j.ToString()).Value = FormatDateTime(CountDate(n), DateFormat.ShortDate) & " 00:00" 'CountDate(n).Date.ToString("dd/MM/yyyy") & " 00:00"
.Range("D" & j.ToString()).Font.Size = 10
.Range("D" & j.ToString()).Font.Color = RGB(34, 54, 34)
End If
Next
End With
'-------------------------------------------------
Dim proc As System.Diagnostics.Process
'proc = System.Diagnostics.Process.GetProcessById(CInt(Me.TextBox1.Text)) ' อันนี้กรณีคุณต้องการระบุ Process ID
proc = System.Diagnostics.Process.GetProcessesByName("EXCEL", My.Computer.Name)(0) ' อันนี้กรณีคุณต้องการทำงานกับ Process แรกสุด ที่จริงควรสร้าง array มาทำงาน แล้วสร้างลูปเพื่อหา process ที่ต้องการ
If Not IsNothing(proc) Then
If MsgBox("EXPORT ข้อมูล " & proc.ProcessName & " เรียบร้อยแล้ว", MsgBoxStyle.OkOnly) = MsgBoxResult.Ok Then
' proc.Kill()
proc.Dispose()
Application.Restart()
End If
End If
'-------------------------------------------------
Catch ex As Exception
' MsgBox(ex.Message)
End Try
End If
'Con_CallData.Close()
End Sub
data:image/s3,"s3://crabby-images/76da1/76da12376c9b7c5207ca233a3e4eaf0474eda886" alt="111 111"
data:image/s3,"s3://crabby-images/e93ea/e93ea5b6504c6f1312ad5a55e3f76ea296ffc268" alt="222 222"
รายงานก็ออกมาประมานนี้แหละครับ
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2013-12-24 16:31:42 |
By :
angelrings0 |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
EPPlus
http://epplus.codeplex.com/
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2013-12-24 17:21:27 |
By :
fonfire |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/f3b89/f3b89ccde25850c65b928bee7cddda844ab028bb" alt=""
|
Load balance : Server 01
|