Импорт и присоединение электронных таблиц

Файлы, созданные приложениями электронных таблиц, управления проектами и т. д. также представляют собой таблицы специального вида. Было бы естественным включить в Access 2002 возможность импорта таких файлов в базу данных Access. И такая возможность в Access 2002 есть. При этом Access 2002 поддерживает следующие форматы:

Этих форматов вполне достаточно, потому что практически все приложения, предназначенные для работы с электронными таблицами, позволяют экспортировать данные в один из этих форматов.

Access 2002 позволяет создавать таблицы в базе данных, импортируя их из рабочего листа Excel. При этом можно импортировать как целый рабочий лист, так и именованный диапазон ячеек этого листа. Кроме того, в процессе импорта может быть создана новая таблицы Access, которая будет содержать все импортируемые данные, или же эти данные будут добавлены к уже существующей таблице Access. При добавлении данных в существующую таблицу заголовки столбцов рабочего листа Excel (во всяком случае, для тех столбцов, которые должны импортироваться) должны совпадать с названиями полей этой таблицы.

Замечание

Импортирование отдельного рабочего листа из рабочей книги возможно, начиная с Microsoft Excel 5.0 и выше. При необходимости импортировать только один рабочий лист из других файлов электронных таблиц, содержащих несколько листов, нужно сначала каждый лист сохранить в отдельном файле.

Для того чтобы импорт прошел без ошибок, данные на импортируемом листе должны быть соответствующим образом организованы. На рис. 3.7 показан формат представления данных на рабочем листе Excel, который наиболее подходит для импорта в базу данных. Обратите внимание на то, что имена всех полей находятся в первой строке таблицы, а оставшиеся строки содержат данные. Тип данных в каждой ячейке одного столбца должен быть одинаковым, и в каждой строке должны использоваться одни и те же поля. В таком виде таблица на рабочем листе максимально соответствует таблице Access, что позволит упростить процесс импорта.

Рабочий лист Excel

Рис. 3.7. Рабочий лист Excel

Для того чтобы подготовить данные на рабочем листе для импорта, может потребоваться выполнить несколько предварительных действий.

  1. Запустите Microsoft Excel и откройте рабочий лист, данные из которого нужно импортировать.
  2. Добавьте, если это необходимо, заголовки столбцов над первой строкой импортируемого диапазона данных. Заголовки столбцов будут применяться в качестве имен полей, поэтому в них нельзя употреблять точку' (.), восклицательный знак (!) и прямоугольные скобки ([]). Нельзя использовать одно имя дважды. Если в заголовках столбцов встречаются запрещенные символы или один заголовок применяется несколько раз, в процессе импорта данных это вызовет сообщение об ошибке.
  3. Если необходимо импортировать не все данные рабочего листа, выделите нужный диапазон ячеек (вместе со строкой заголовка), а затем выберите команду Вставка, Имя, Присвоить (Insert, Name, Define) и присвойте имя выделенному диапазону.
  4. Сохраните рабочий лист и закройте приложение Excel.

Замечание

Если ячейки рабочего листа содержали формулы, по которым вычислялись значения, то в таблицу Access будут импортированы только вычисленные значения.

Теперь данные рабочего листа можно импортировать в таблицу Access 2002. Для этого:

  1. Запустите Access 2002 и откройте базу данных, в которую необходимо импортировать данные. Активизируйте окно База данных (Database), щелкнув по его заголовку левой кнопкой мыши.
  2. Выберите команду Файл, Внешние данные, Импорт (File, Get External Data, Import). Появится диалоговое окно Импорт (Import).
  3. Перейдите в папку, содержащую файл рабочего листа Excel. В раскрывающемся списке Тип файла (File of Type) выделите элемент Microsoft Excel (*.xls). Выделите имя файла и нажмите кнопку Импорт (Import) или просто дважды щелкните по имени файла левой кнопкой мыши. Запустится Мастер импорта электронной таблицы (Import Spreadsheet Wizard), первое диалоговое окно которого показано на рис. 3.8.
  4. Если необходимо импортировать весь рабочий лист, выберите переключатель листы (Show Worksheets). Если же предполагается импортировать именованный диапазон рабочего листа, то выберите переключатель именованные диапазоны (Show Named Ranges). В списке первого диалогового окна Мастера импорта электронных таблиц будут выведены имена рабочих листов или диапазонов, соответственно. На рис. 3.8 список объектов состоит только из одного наименования "Клиенты", т. к. импортируемая таблица имеет один рабочий лист.

    Первое диалоговое окно Мастера импорта электронной таблицы

    Рис. 3.8. Первое диалоговое окно Мастера импорта электронной таблицы

  5. Выделите нужное имя рабочего листа или диапазона ячеек. В нижней части первого окна мастера импорта выводится образец данных из выделенного элемента электронной таблицы. Нажмите кнопку Далее (Next), чтобы перейти к следующему шагу мастера. Появится диалоговое окно, изображенное на рис. 3.9.
  6. Если первая строка импортируемых данных содержит заголовки столбцов, то их можно использовать в качестве имен полей. Для этого установите флажок Первая строка содержит заголовки столбцов (First Row Contains Column Headings). Снова нажмите кнопку Далее (Next). Появится диалоговое окно, показанное на рис. 3.10.

    Второе диалоговое окно Мастера импорта электронной таблицы

    Рис. 3.9. Второе диалоговое окно Мастера импорта электронной таблицы

    Третье диалоговое окно Мастера импорта электронной таблицы

    Рис. 3.10. Третье диалоговое окно Мастера импорта электронной таблицы

  7. В этом диалоговом окне можно указать, где необходимо сохранить импортируемые данные — в новой таблице или в существующей. Выберите нужный переключатель и, при необходимости, нужную таблицу в списке в существующей таблице (In ah Existing Table). Нажмите кнопку Далее (Next). Если вы добавляете данные к уже существующей таблице, то все промежуточные шаги будут пропущены и появится последнее диалоговое окно мастера (см. шаг 12). Если же вы создаете новую таблицу, то появится диалоговое окно, показанное на рис. 3.11.
  8. В этом окне вы можете выбрать те столбцы, которые нужно импортировать (это необязательно все столбцы рабочего листа), и ввести некоторые параметры для полей будущей таблицы. Чтобы не импортировать (пропустить) какое-либо поле (столбец рабочего листа), выделите его и установите флажок не импортировать (пропустить) поле (Do not import field).
  9. Мастер импорта электронных таблиц позволяет изменить или добавить (если они не определены в первой строке рабочего листа) имена полей таблицы, соответствующих столбцам рабочего листа. Для этого выделите столбец, щелкнув по нему левой кнопкой мыши, а затем укажите имя в текстовом поле имя поля (Field Name) (горизонтальная полоса прокрутки в диалоговом окне позволяет просмотреть все столбцы листа).
  10. Если какое-либо поле нужно проиндексировать, выберите требуемый тип индекса в раскрывающемся списке индекс (Indexed).

    Четвертое диалоговое окно Мастера импорта электронной таблицы

    Рис. 3.11. Четвертое диалоговое окно Мастера импорта электронной таблицы

  11. Если данные рабочего листа не форматировались или были отформатированы как текст, Access позволяет выбрать тип данных для каждого поля при помощи раскрывающегося списка тип данных (Data Type). На рис. 3.11 раскрывающийся список тип данных недоступен, поскольку импортируемый рабочий лист содержал форматирование, которое Access 2002 смог распознать автоматически.
  12. Повторите шаги 9—11 для каждого столбца импортируемых данных. После того как заданы все имена и типы данных полей, определены проиндексированные поля, а также столбцы, которые нужно пропустить при импорте, нажмите кнопку Далее. Появится следующее диалоговое окно мастера импорта (рис. 3.12).
  13. На пятом шаге Мастера импорта электронной таблицы можно определить ключевое поле новой таблицы. Чтобы Access 2002 автоматически добавил к импортируемой таблице ключевое поле с типом данных Счетчик и присвоил уникальный номер каждой строке таблицы, выберите переключатель автоматически создать ключ (Let Access add Primary Key). Чтобы определить один из столбцов импортируемого диапазона ячеек в качестве ключевого поля таблицы, выберите переключатель определить ключ (Choose my own Primary Key) и выделите в раскрывающемся списке название столбца. Если для импортируемой таблицы не требуется определение ключевого поля, выберите переключатель не создавать ключ (No Primary Key). Нажмите кнопку Далее. Появится последнее диалоговое окно.

    Пятое диалоговое окно Мастера импорта электронной таблицы

    Рис. 3.12. Пятое диалоговое окно Мастера импорта электронной таблицы

    Совет

    Прежде чем определить ключевое поле на основе одного из столбцов таблицы, убедитесь в том, что ячейки этого столбца содержат уникальные значения.

  14. В поле ввода Импорт в таблицу (Import to Table) укажите имя новой таблицы. По умолчанию Access 2002 использует имя импортируемого рабочего листа или диапазона ячеек в качестве имени новой таблицы. Сразу после завершения импорта данных можно вызвать Анализатор таблиц, позволяющий оптимизировать структуру таблицы, например исключать повторяющиеся данные. В этом случае необходимо установить флажок Проанализировать таблицу после импорта данных (I would like a wizard to analyze my table after importing the data). Нажмите кнопку Готово (Finish), чтобы завершить процесс импорта данных. После того как импорт данных будет завершен, появится сообщение об успешном окончании операции.

Замечание

Если имя таблицы, которое вы указали на последнем шаге Мастера импорта электронной таблицы, совпадет с именем уже существующей в базе данных таблицы, то Access 2002 выведет диалоговое окно, в котором спросит у вас, заменить ли уже существующую таблицу новой или переименовать создаваемую таблицу.

При автоматическом определении типов данных полей импортируемой таблицы Access просматривает первые 20 строк импортируемого диапазона ячеек. Например, если каждый столбец в импортируемом диапазоне содержит числовые данные, то полю, соответствующему этому столбцу, присвоится один из числовых подтипов данных (выбор подтипа зависит от параметров форматирования рабочего листа Excel). Если же в первых 20 ячейках столбца содержатся числа, а в остальных встречается текст, то Access уже не изменяет тип данных поля, а создает таблицу ошибок импорта, в которой каждая запись соответствует одной ошибке. После окончания процесса импорта в случае возникновения ошибок выдается сообщение об этом (рис. 3.13) и указывается имя таблицы ошибок импорта.

Таблица ошибок импорта (рис. 3.14) позволяет найти записи, в которых возникли ошибки, и исправить их. Однако более правильным способом будет исправить рабочий лист Excel и повторить импорт данных. После исправления ошибок удалите эту таблицу.

Импортированная таблица появится в окне базы данных. Чтобы проверить, что желаемый результат достигнут, откройте импортированную таблицу в режиме Таблицы, дважды щелкнув по ней левой кнопкой мыши.

Сообщение 1

Сообщение 2

Сообщение 3

Рис. 3.13. Сообщение о возникновении ошибок импорта

Таблица ошибок импорта

Рис. 3.14. Таблица ошибок импорта

Чтобы узнать, какие типы данных полей были выбраны при импорте рабочего листа, в окне базы данных откройте созданную таблицу в режиме Конструктора (рис. 3.15). В отличие от присоединенных таблиц, все свойства полей импортированных таблиц можно изменить.

Импортированная таблица в режиме Конструктора

Рис. 3.15. Импортированная таблица в режиме Конструктора

Access 2002 позволяет также связать рабочий лист Excel с базой данных Access. Благодаря этой возможности с присоединенным рабочим листом Excel можно работать как в исходном формате средствами Excel, так и в формате таблицы базы данных Access, причем это можно делать одновременно. Что касается изменения структуры рабочего листа, то на него распространяются правила работы с присоединенными таблицами, т. е. в режиме Конструктора можно изменить только те свойства полей, которые связаны с отображением этих полей в таблицах Access. При изменении структуры таблицы или перемещении ее в другую папку нужно обновить связь с ней.

Присоединение рабочего листа Excel выполняется практически так же, как и импорт, только используется команда Связь с таблицами (Link Tables). Мастер связывания электронной таблицы (Link Spreadsheet Wizard) аналогичен мастеру импорта, однако он не позволяет выбирать столбцы рабочего листа и изменять их параметры.