Содержание
Изучение того, как использовать Visual Basic для приложений для импорта данных в Access, может сделать ваше приложение базы данных более динамичным. В VBA вы можете использовать комбинацию объектов, чтобы открыть лист Excel и импортировать данные в таблицу Access. Используйте библиотеку объектов для Microsoft Excel в VBA, чтобы открыть лист. Объект Recordset используется для открытия таблицы в Access и сохранения данных, импортированных из Excel. Использование VBA для импорта данных значительно сокращает время, затрачиваемое на выполнение процесса вручную.
направления
Импорт данных из Excel для доступа с использованием библиотеки объектов Excel (Jupiterimages / Photos.com / Getty Images)-
Откройте Microsoft Excel и введите «data1» в A2 и «data2» в B2. Нажмите Ctrl + S, чтобы сохранить документ. Сохраните лист в «C: Temp » с именем «dataToImport.xlsx». Нажмите Сохранить, а затем закройте Excel.
-
Запустите Microsoft Access, нажмите «Новая база данных» и нажмите «Создать». Нажмите «Инструменты базы данных» и нажмите «Visual Basic», чтобы открыть редактор VB. Нажмите меню «Вставить» и нажмите «Модуль», чтобы вставить новый код модуля. Откройте меню «Сервис», затем «Ссылки» и установите флажок рядом с «Библиотека объектов Microsoft Excel».
'. -
Начните с ввода следующего кода VBA для создания новой подпроцедуры:
Private Sub importExcelData ()
-
Введите следующий код для создания переменных, которые будут использоваться для чтения Excel:
Dim xlApp As Excel.Application Dim xlBk As Excel.Workbook Dim xlSht As Excel.Worksheet
-
Введите следующий код для создания переменных, которые будут использоваться в Access:
Dim dbRst как набор записей Dim dbs как база данных Dim SQLStr как строка
-
Введите следующий код, чтобы определить объекты банка, а также определить, какой лист использовать:
Установить dbs = CurrentDb Установить xlApp = Excel.Application Установить xlBk = xlApp.Workbooks.Open ("C: Temp dataToImport.xlsx") Установить xlSht = xlBk.Sheets (1)
-
Создайте новую таблицу с двумя столбцами в Access для импорта данных Excel. Введите следующий код для создания таблицы с использованием объекта DoCmd:
SQLStr = "CREATE TABLE excelData (columnOne TEXT, columnTwo TEXT)" DoCmd.SetWarnings False DoCmd.RunSQL (SQLStr)
-
Откройте таблицу, которую вы только что создали с помощью объекта Recordset. Введите следующий код, чтобы открыть таблицу и добавить новую строку:
Установите dbRst = dbs.OpenRecordset ("excelData") dbRst.AddNew
-
Введите следующий код, чтобы получить значения в рабочей таблице Excel, сохранить их в своей таблице и обновить запись:
xlSht.Range ("A2") Выберите dbRst.Fields (0) .Value = xlSht.Range ("A2"). Значение xlSht.Range ("B2"). Выберите dbRst.Fields (1) .Value = xlSht. Диапазон ("B2"). Значение dbRst.Update
-
Завершите процедуру, введя следующий код VBA:
dbRst.Close dbs.Close xlBk.Close End Sub
-
Нажмите F5, чтобы выполнить процедуру. Данные в рабочей таблице Excel будут импортированы в вашу таблицу доступа.