Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal _ hWnd As Long, ByVal wMsg As Long, ByVal wParam As Long, _ lParam As Any) As LongPrivate Declare Function LockWindowUpdate Lib "user32" (ByVal hwndLock As Long) _ As Long Const LB_RESETCONTENT = &H184Const LB_GETCOUNT = &H18BConst LB_GETTEXT = &H189Const LB_ADDSTRING = &H180Const LB_GETITEMDATA = &H199Const LB_SETITEMDATA = &H19A' Duplicate the contents of a ListBox control to another ListBox control'' Pass False to the last argument to append contents' (the target control isn't cleared before adding elements)'' uses API functions for the fastest codeSub DuplicateListBox(Source As ListBox, Target As ListBox, _ Optional AppendMode As Boolean) Dim index As Long Dim itmData As Long Dim numItems As Long Dim sItemText As String ' prepare the receiving buffer sItemText = Space$(512) ' temporarily prevent updating LockWindowUpdate Target.hWnd ' reset target contents, if not in append mode If Not AppendMode Then SendMessage Target.hWnd, LB_RESETCONTENT, 0, ByVal 0& End If ' get the number of items in the source list numItems = SendMessage(Source.hWnd, LB_GETCOUNT, 0&, ByVal 0&) For index = 0 To numItems - 1 ' get the item text SendMessage Source.hWnd, LB_GETTEXT, index, ByVal sItemText ' get the item data itmData = SendMessage(Source.hWnd, LB_GETITEMDATA, index, ByVal 0&) ' add the item text to the target list SendMessage Target.hWnd, LB_ADDSTRING, 0&, ByVal sItemText ' add the item data to the target list SendMessage Target.hWnd, LB_SETITEMDATA, index, ByVal itmData Next ' allow redrawing LockWindowUpdate 0 End Sub


Different Types of Data Models Explained with Examples
In the modern world, data is everything and everywhere. With so much access to technology, data has become a valuable resource for any business. Albeit a complex one. Data is