:D snasui.com ยินดีต้อนรับ :D
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย :thup: สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ :arrow: ระบุ Version ของ Excel
:!: โปรดทราบ :!:
  1. กรุณาอ่านกฎการใช้บอร์ด (Forum rules) ในตำแหน่งด้านบนของแต่ละบอร์ด
  2. การสมัครสมาชิก การ Login การกู้คืนรหัสผ่าน
    1. สมัครสมาชิกดูขั้นตอนได้ที่ :arrow: สมัครสมาชิก
    2. Login เข้าระบบโดยคลิกปุ่ม Login ตรงมุมขวาบนของหน้านี้ :roll:
    3. การ Login ผ่าน Facebook ดูวิธีที่ :arrow: Login ผ่าน Facebook
    4. ลืมรหัสผ่านสามารถรับรหัสใหม่ได้ที่ :arrow: Reset รหัสผ่าน
  3. มีปัญหาการใช้งาน แจ้งผู้ดูแลระบบได้ที่ :arrow: ติดต่อผู้ดูแลระบบ
  4. กำหนดการตั้งค่าส่วนตัว เช่นตั้งค่าภาษาเป็นไทยหรืออังกฤษดูได้ที่ :arrow: ตั้งค่าส่วนตัว
  5. การตั้งและตอบกระทู้ดูได้ที่ :arrow: วิธีการตั้งและตอบกระทู้
  6. การจัดรูปแบบตัวอักษรด้วย bbcode ในช่องแสดงความคิดเห็นดูได้ที่ :arrow: จัดรูปแบบตัวอักษร
  7. กำหนดขนาดตัวอักษรใน Browser ดูได้ที่ :arrow: กำหนดขนาดตัวอักษรใน Browser

กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

ฟอรัมถาม-ตอบปัญหาการใช้งานสูตรและฟังก์ชัน Excel
Forum rules
  1. ไม่อนุญาตให้ใช้ภาษาแชทในการถามและตอบปัญหา ไม่ใช้คำว่า "คับ" หรือ "อ่ะครับ" แทนคำว่า "ครับ" ไม่ใช้คำว่า "เด๋ว" แทนคำว่า "เดี๋ยว" เป็นต้น เนื่องจากเมื่อแปลเป็นภาษาต่างประเทศแล้วจะให้ความหมายผิดไปจากที่ควรจะเป็น
  2. ห้ามถามโดยระบุชื่อผู้ตอบและต้องตั้งชื่อกระทู้ให้สื่อถึงปัญหาที่จะถาม ไม่ตั้งชื่อว่า ช่วยด้วยครับ, มีปัญหามาปรึกษาครับ เป็นต้น
  3. กรุณาอธิบายปัญหาและระบุคำตอบที่ต้องการมาในกระทู้ด้วยเสมอถึงแม้จะอธิบายไว้ในไฟล์แนบแล้วก็ตาม ทั้งนี้เพื่ออำนวยความสะดวกแก่เพื่อนสมาชิกในการค้นหาข้อมูล
  4. กรุณาแนบไฟล์ตัวอย่างพร้อมแสดงคำตอบที่ถูกต้องมาในไฟล์ด้วยเพื่อให้ง่ายต่อการทำความเข้าใจและสะดวกต่อการตอบคำถาม (ขนาดไฟล์ไม่เกิน 500Kb ขนาดภาพไม่เกิน 800*600 Pixel) ไม่แนบเป็น Link มาจากแหล่งอื่นที่อาจจะถูกลบทิ้งไปโดยต้นทางในภายหลัง นอกจากนี้ไม่ควรแนบไฟล์ที่มีข้อมูลสำคัญอันก่อให้เกิดความเสียหายกับตนเองและผู้อื่น
  5. กรณีเป็นคำถามเกี่ยวกับ Programming เช่น VBA, VB.Net, C#, SQL ฯลฯ ต้องลองเขียนมาเองก่อนเสมอ ถามเฉพาะที่ติดปัญหา ระบุ Module, Procedure ที่ติดปัญหาให้ชัดเจน กรุณาโพสต์ Code ให้แสดงเป็น Code คือเปิดด้วย [code] และปิดด้วย [/code] ตัวอย่างเช่น [code]dim r as range[/code] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
  6. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
sakajohn
Member
Member
Posts: 229
Joined: Tue Aug 06, 2013 10:55 am
Excel Ver: 2010

กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

#1

Post by sakajohn »

รบกวนสอบถามครับ ผมแชร์ไฟล์ DataBase ไว้ โดยให้แต่ละ user ทำการบันทึกข้อมูลต่อกันลงไปเรื่อยๆ โดยให้เปิดไฟล์ขึ้นมาแล้วทำการบันทึก เมื่อบันทึกเสร็จให้saveและปิดไฟล์ แต่มีบางครั้งที่ User บันทึกข้อมูลใน Cell เดียวกันทำให้เกิด error ไม่สามารถบันทึกไฟล์ได้ ถ้าปิดไฟล์ DataBaseไป มันก็จะไปเริ่มคำสั่งใหม่ตั้งแต่ต้น ผมต้องการว่า ถ้าเกิด Error ให้แต่ละคนกลับมาบันทึกข้อมูลใหม่ ตรงคำสั่ง บันทึกงาน Databaseแค่นั้นครับ ผมจะต้องแก้ไข code อย่างไรครับ พอดีไฟล์งานใหญ่เลยไม่ได้แนบมาด้วยครับ

Code: Select all

Sub Macro1()
' Macro1 Macro
'

'
Dim rg As Range

Set rg = Range("T9")
Set rg = Range("U17")

rg.Activate
If Application.CountA(Range("T9")) = 0 Then
    MsgBox "กรุณากรอกข้อมูลให้ครบ"
    Exit Sub
End If
rg.Activate
If Application.CountA(Range("U17")) = 0 Then
    MsgBox "กรุณาระบุสถานที่ส่งของ"
    Exit Sub
End If
Dim x As Integer
    x = MsgBox("ต้องการพิมพ์ใบจ่ายงาน ใช่หรือไม่", vbOKCancel)
    If x = vbCancel Then
    Sheets("sheet2").Select
    Else
MsgBox "ใส่ใบจ่ายงานด้วยครับ"
ActiveSheet.Unprotect Password:="1234"
Range("L56") = Range("L56") + 1
If Range("AC10").Value <> 0 Then
MsgBox ("รหัสซ้ำ กรุณาสั่งพิมพ์อีกครั้ง"), vbCritical
Exit Sub
Else

'บันทึก SaleData
   Application.Goto Reference:= _
        "OFFSET(R9C30,1,0,COUNTIF(C34,"">0""),COUNTA(R9)-4)"
    Selection.Copy
    Workbooks("SaleData.xlsx").Activate
    Sheets("NOI").Select
    Application.Goto Reference:="OFFSET(R1C1,COUNTA(C1),0)"
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    ActiveWorkbook.Save
ThisWorkbook.Activate
     
     'บันทึกงาน DataBase
    Application.Goto Reference:= _
        "OFFSET(R9C30,1,0,COUNTIF(C34,"">0""),COUNTA(R9)-4)"
    Selection.Copy
    Workbooks.Open Filename:="\\ACCOUNT\Data (D)\SALE\DataBase.xlsx"
    Sheets("Sheet1").Select
    Application.Goto Reference:="OFFSET(R1C1,COUNTA(C1),0)"
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    ActiveWorkbook.Save
    ActiveWorkbook.Close
    
    
   
   ActiveSheet.PageSetup.PrintArea = "$A$1:$W$60"
    Application.ActivePrinter = "NOI on Ne00:"
    ActiveWindow.SelectedSheets.PrintOut Copies:=3, ActivePrinter:= _
            "NOI on Ne00:", Collate:=True, IgnorePrintAreas:=False
    'ActiveWindow.SelectedSheets.PrintOut Copies:=3
    
    
    Range("t9,e15,I18,P18,T18,I22,P22,T22,I26,P26,T26,I30,P30,T30,I34,P34,T34,I38,P38,T38,N44,N46,N48,N5,U17").Select
    Range("t9,e15,I18,P18,T18,I22,P22,T22,I26,P26,T26,I30,P30,T30,I34,P34,T34,I38,P38,T38,N44,N46,N48,N50,U17").Activate
    Selection.ClearContents
    Range("i18").Select
    ActiveSheet.Protect Password:="1234"
    MsgBox ("บันทึกข้อมูลเรียบร้อย"), vbInformation
    End If
User avatar
snasui
Site Admin
Site Admin
Posts: 31257
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

#2

Post by snasui »

:D การบันทึกข้อมูลไปยังไฟล์ที่ Shared ไว้ ไม่ควรจะเกิด Error ครับ

การ Shared ไฟล์สามารถทำงานพร้อมกันได้ถึง 255 คน

วิธีการ Shared ที่ถูกต้องสำหรับไฟล์ Database คือ เข้าเมนู Review > Share Workbook > เลือก Allow change by more than one user...

วิธีที่ถูกต้องสำหรับการบันทึกคือ ใช้ Code เปิดไฟล์ Database นี้ขึ้นมา > Save > บันทึก > Save > Close

สังเกตว่าจะมีการ Save ก่อนหนึ่งครั้งแล้วค่อยบันทึก ทั้งนี้เพื่อให้ข้อมูลในไฟล์ Database เป็นข้อมูลที่ถูกบันทึกมาล่าสุดเพราะคนอื่นอาจจะทำงานอยู่ด้วยและทำการบันทึกก่อนเราจะบันทึก เราจะได้บันทึกต่อจากนั้นไม่ใช่บันทึกทับกับของคนอื่น

กรณีไฟล์ใหญ่ ให้ Save As ไปเป็นไฟล์สำรองแล้วตัดมาเฉพาะที่เกี่ยวข้องกับคำถามนี้เท่านั้น ไม่จำเป็นต้องส่งไฟล์ต้นฉบับมาครับ
sakajohn
Member
Member
Posts: 229
Joined: Tue Aug 06, 2013 10:55 am
Excel Ver: 2010

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

#3

Post by sakajohn »

ถ้าผมแก้เป็นแบบนี้ถูกต้องมั้ยครับ

Code: Select all

'บันทึกงาน DataBase
    Application.Goto Reference:= _
        "OFFSET(R9C30,1,0,COUNTIF(C34,"">0""),COUNTA(R9)-4)"
    Selection.Copy
    Workbooks.Open Filename:="\\ACCOUNT\Data (D)\SALE\DataBase.xlsx"
    ActiveWorkbook.Save
    Sheets("Sheet1").Select
    Application.Goto Reference:="OFFSET(R1C1,COUNTA(C1),0)"
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    ActiveWorkbook.Save
    ActiveWorkbook.Close
User avatar
snasui
Site Admin
Site Admin
Posts: 31257
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

#4

Post by snasui »

:D วิธีการที่ผมแจ้งไปครอบคลุมไปถึงการเปิดไฟล์ Database ค้างไว้และปิดเมื่อเสร็จงานแล้ว แต่หากว่าในการทำงานจริงเป็นการเปิดแล้วบันทึกทันที ความจำเป็นในการ Save ก่อนที่จะบันทึกก็จะน้อยลงไป แต่ทำไว้ด้วยก็ไม่เสียหายอะไร

จาก Code ที่เขียนมาลองนำไปทดสอบใช้งานดูแล้วสังเกตว่าได้ผลหรือไม่อย่างไร ติดตรงไหนค่อยนำมาถามกันต่อครับ
sakajohn
Member
Member
Posts: 229
Joined: Tue Aug 06, 2013 10:55 am
Excel Ver: 2010

Re: กำหนด Format cell ไม่ให้เปลี่ยน

#5

Post by sakajohn »

snasui wrote: Sat Aug 18, 2018 5:27 pm :D เรื่องการ Share File ผมหมายถึงให้กลับไปถามตอบกันในกระทู้นี้ครับ viewtopic.php?f=3&t=14009

ในการใช้งานจริงได้มีการกำหนดการ Shared ให้กับไฟล์ DataBase.xlsx หรือไม่ครับ ไฟล์ที่แนบมายังไม่ได้กำหนด ช่วยกำหนดมาให้ด้วยครับ

ปกติแชร์ไฟล์ไว้ครับ
You do not have the required permissions to view the files attached to this post.
Last edited by snasui on Sun Aug 19, 2018 7:02 am, edited 1 time in total.
Reason: ย้ายโพสต์ให้ตรงกับกระทู้
User avatar
snasui
Site Admin
Site Admin
Posts: 31257
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

#6

Post by snasui »

:D ตัวอย่างการปรับ Code ครับ

Code: Select all

'Other code...
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
On Error GoTo SaveAgain
    Err.Clear ' or Err = 0
    ActiveWorkbook.Save
    ActiveWorkbook.Close
    ThisWorkbook.Activate
SaveAgain:
    If Err <> 0 Then Resume
    'สั่งพิมพ์
    Range("Q13:W13").Select
    With Selection.Font
'Other code...
Post Reply