Re: Data realtime แสดงด้วย pivot table จาก access query
Posted: Thu Aug 04, 2011 6:58 am
-2 ตามด้านบนเป็นการระบุค่าในเซลล์ครับ หากเปลี่ยนเป็น -1 ก็จะไปอ้างอิงเซลล์อื่น ทำให้เงื่อนไขไม่ถูกต้อง ส่วนคำตอบที่ถูกต้องอาจจะเป็นความบังเอิญgodman wrote:อาจารย์ครับจากตรงนี้ ถ้าผมเปลี่ยนเป็น -1 หมายความว่าให้เอาข้อมูลประวัติก่อนหน้าจนถึงวันที่เวลาตามที่เลือกในช่อง B2 ใช่ไหมครับ เพราะผมลองเปลี่ยนแล้วมันโอเค นำไปใช้ได้ไใช่ไหมครับ และนำไปประยุกต์ใช้ในเรื่องอื่นๆได้ด้วยใช่ไหมครับ ผมตื่นเต้นมากที่มันทำได้
CDbl(r.Offset(, -2)) <= CDbl(Worksheets("Pivot Summary").Range("B2")) Then
r.Offset(0,-2) หมายถึงเซลล์ด้านซ้ายของเซลล์ตัวแปร r ซึ่งเป็นเซลล์ที่ 2 (ไม่นับตัวแปร r)
r.Offset(0,-1) หมายถึงเซลล์ด้านซ้ายของเซลล์ตัวแปร r ซึ่งเป็นเซลล์ที่ 1 (ไม่นับตัวแปร r)
r.Offset(0,0) หมายถึงเซลล์ตัวแปร r
ส่วนไฟล์ที่แนบมาไม่มี Code มาด้วยครับ เงื่อนไขจากวันที่ x ถึงวันที่ y จะต้องมีช่องให้ระบุวันที่ทั้งสองวันด้วยนะครับ
ส่วนถ้าจะหาวันที่ในวันก่อนหน้าจนถึงวันที่ใน B2 ตามที่อธิบายมาในเซลล์ D4 ผมเขียน Code ให้แล้วตามนี้ครับ
snasui wrote: สำหรับ Code ที่ผมเขียนนั้น เป็นการตรวจสอบตามด้านล่างครับ
ในเซลล์ B2 ชีท Pivot Summary กรอกวันที่ใดไว้ โปรแกรมจะดึงข้อมูลตั้งแต่วันนั้นจนถึงปัจจุบันครับ ถ้ากรอกวันที่ปัจจุบันก็ได้ข้อมูลเพียงวันปัจจุบันเท่านั้นครับ
snasui wrote: ผมปรับ Code ให้ใหม่ตามด้านล่างเพื่อให้ Run ได้แม้ว่าจะเกิด Error ครับCode: Select all
Sub FillData() Dim rAll As Range Dim r As Range On Error Resume Next With Worksheets("Data input") Set rAll = .Range("E2", .Range("E2").End(xlDown)) End With For Each r In rAll If CInt(Mid(r, 3, 3)) = Worksheets("Pivot Summary").Range("B1") And _ (CDbl(r.Offset(, -2)) >= CDbl(Worksheets("Pivot Summary").Range("B2")) _ And CDbl(r.Offset(, -2)) <= CDbl(Date + Time)) Then r.Offset(, 8) = True Else r.Offset(, 8) = False End If Next r If Application.CountIf(Worksheets("Data input").Range("M:M"), True) = 0 Then MsgBox "Can not found data." Exit Sub Else Worksheets("Pivot Summary").PivotTables(1).PivotCache.Refresh End If MsgBox "Finish." End Sub