2013-04-26 80 views
1

我有一張表,並且使用了我創建的表單。使用用戶表單中的數據更新工作表

  1. 用戶形式挑選和姓從表中通過組合框
  2. 用戶需要從組合框中選擇「是/否」這個

我需要一個vba代碼(excel),以便能夠在表 中找到該名稱(在用戶選中之後),然後通過正確的行更新是/否列。

table

+0

什麼是你最好的拍攝這麼遠? (顯示代碼) – 2013-04-26 19:59:24

+0

查詢/導入表。或工作簿中完全駐留的表? – user2140261 2013-04-26 23:34:02

+0

表來源於工作表名爲「工人」 – 2013-04-27 19:47:54

回答

0

我創建一個模塊,並添加了此:

Option Explicit 
Public Sub update_sheet(workername As String) 
'--> If the user was selected on the form update column F to Yes 
    Dim ws As Worksheet 
    Dim rowno As Long 

    Set ws = Sheets("workers") 

    With ws 
     rowno = .Range("C:C").Find(workername).Row 
     .Cells(rowno, 6).Value = "Yes" 
    End With 
End Sub 

在表單代碼:

Private Sub cb_select_change() 
    Call update_sheet(cb_select.Value) 
End Sub 

在您的組合框被稱爲cb_select Select Doe from the list

Populates the appropriate cell with Yes

+0

tnx alistair它的工作原理 – 2013-05-01 23:07:37

0

你需要做一些這方面的工作,使之成爲你所需要的,但它應該讓你開始:

Private Sub CommandButton1_Click() 

Dim rng_ToSearch As Excel.Range 
Dim rng_Found As Excel.Range 

On Error GoTo ErrorHandler 

'Change this to the range that contains your names. I'm assuming that 
'it's a single column and has the Yes/No column alongside. 
Set rng_ToSearch = Sheet1.Range("MyTable_Names") 

'Change the What argument to reflect the name of your form's 
'control. 
Set rng_Found = rng_ToSearch.Find(What:=Me.ComboBox1.Value, _ 
    After:=rng_ToSearch.Range("A1"), LookIn:=xlFormulas, _ 
    LookAt:=xlPart, SearchOrder:=xlByRows, SearchDirection:=xlNext, _ 
    MatchCase:=False, SearchFormat:=False) 


'This shouldn't happen if you've populated the name selection 
'box correctly and have not allowed users to add to it. 
'This is left as an exercise for the reader. 
If rng_Found Is Nothing Then 
    Err.Raise vbObjectError + 2000, , "Either the selected name was " _ 
    & "not found in the list, or no selection was made." 
End If 

'Again, change the control name to your own. 
rng_Found.Offset(0, 1) = Me.ComboBox2.Value 

ExitPoint: 
On Error Resume Next 
Set rng_ToSearch = Nothing 
Set rng_Found = Nothing 
On Error GoTo 0 

Exit Sub 

ErrorHandler: 

MsgBox "Error in updating users: " & Err.Number & vbCrLf & Err.Description 

Resume ExitPoint 

End Sub 
+0

謝謝艾倫虐待後來看看它是怎麼回事 – 2013-04-27 07:02:51

0

THIS IS到目前爲止我的代碼

Private Sub RefEdit1_BeforeDragOver(Cancel As Boolean, ByVal Data As msforms.DataObject, ByVal x As stdole.OLE_XPOS_CONTAINER, ByVal y As stdole.OLE_YPOS_CONTAINER, ByVal DragState As msforms.fmDragState, Effect As msforms.fmDropEffect, ByVal Shift As Integer) 

End Sub 

Private Sub ClsFrmE_Click() 
Unload Me 
End Sub 





Private Sub cmdAdd_Click() 
Dim lRow As Long 
Dim ws As Worksheet 
Set ws = Worksheets("workers") 




'???÷? ?? ?????? ????? 
If Trim(Me.cmbWN.Value) = "" Then 
    Me.cmbWN.SetFocus 
    MsgBox "???? ?? ????" 
    Exit Sub 
End If 

If Trim(Me.tbDate.Value) = "" Then 
    Me.tbDate.SetFocus 
    MsgBox "???? ????? ?????" 
    Exit Sub 
End If 


'copy the data to the database 
'use protect and unprotect lines, 
'  with your password 
'  if worksheet is protected 
With ws 
' .Unprotect Password:="password" 
    If Trim(Me.dNdcmb.Value) = "????" Then 
    .Cells(lRow, 6).Value = 1 
    Else 
    .Cells(lRow, 6).Value = 0 
    End If 
    .Cells(lRow, 7).Value = Me.tbDate.Value 
    '.Cells(lRow, 2).Value = Me.cboPart.List(lPart, 1) 
' .Protect Password:="password" 
End With 

'clear the data 
Me.cmbWN.Value = "" 
Me.tbDate.Value = "" 

Me.cmbWN.SetFocus 

ActiveWorkbook.Save 
End Sub 
Private Sub UserForm_Initialize() 
Dim cFullName As Range 
Dim cDnd As Range 

Dim ws As Worksheet 
Set ws = Worksheets("workers") 

For Each cFullName In ws.Range("??????") 
    With Me.cmbWN 
    .AddItem cFullName.Value 
    .List(.ListCount - 1, 1) = cFullName.Offset(0, 1).Value 
    End With 
Next cFullName 

For Each cDnd In ws.Range("??????????") 
    With Me.dNdcmb 
    .AddItem cDnd.Value 

    End With 
Next cDnd 
Me.dNdcmb.Text = Me.dNdcmb.List(Me.dNdcmb.ListCount - 2) 
Me.cmbWN.SetFocus 
End Sub 
相關問題