Как сделать маску ввода в access
После просмотра данного видеоурока вы сможете САМОСТОЯТЕЛЬНО создать любую маску ввода для ввода данных в базе данных Microsoft Access.
Убедитесь, что программа Microsoft Access очень проста и не требует дополнительных знаний в освоении.
Таймкоды:
00:00 | Что такое маска ввода?
01:41 | Настройка маски ввода с помощью мастера
05:10 | Настройка маски ввода с помощью конструктора
08:02 | Из чего состоит маска ввода?
08:54 | Заключение
Комментарии • 94
00:00 | Что такое маска ввода?
01:41 | Настройка маски ввода с помощью мастера
05:10 | Настройка маски ввода с помощью конструктора
08:02 | Из чего состоит маска ввода?
Спасибо за уроки. Отличный стиль объяснения: кратко, точно.
Замечание: то, что Вы называете "нижний слэш", правильно называть "подчёркивание". Слэш - это "косая черта".
Понял. Спасибо что смотрите)))
То что надо! как раз собирался делать маски для своей базы
Спасибо большое.
пользуйтесь. Расскажите друзьям, пусть тоже научатся.
Спасибо за полезные и понятные видео! Скажите пожалуйста где скачать табличку символов для ввода данных в маске ввода?
Здравствуйте ещё раз! Спасибо большое автору видео за все уроки. У меня есть вопрос по маске ввода. Но не знал - туда ли этот вопрос. Получается сделал я маску ввода на паспорт и на телефон это отлично. Но тут ещё задача - пытаюсь сделать базу данных для спортивных игр. Это и футбол и другие. И получается для футбола я делаю - и у меня появляется выпадающий список результатов матча. Это такие результаты, как 1:0, 2:0, 2:1, 2:2, 2:3 и т.д. То есть чтобы не писать счёт вручную и два раз (в двух столбцах) у меня это всё в одном столбце сделано с помощью мастера подстановки. Но тут возникает проблема.
Аксесс не воспринимает данный тип, как то 1:0, 2:0 как числовой. Т.е. получается, что дальше работать с этими цифрами нельзя. Можно ли как то указать аксессу, что это двоеточие - это означает вычесть из большего меньшее. И чтобы он понимал, что это разные числа и из 1 вычитал 0 и результат математически через запрос вносил в другой столбец, где уже бы было написано -1. Либо при ничейной исходе было бы написано 0 (т.к. 1:1, 2:2 и т.д. это 0. Т.к. 1-1 = 0 и 2-2=0).
Или как вариант можно ли это 1:0 заменить на 1-0, чтобы он сразу делал эту математическую операцию и вносил результат в другой столбец. Как это сделать?
У меня есть поле с идентификатором клиента, который должен быть в формате C0000000001, где у него есть буква в начале и до 10 цифр после буквы с ведущими нулями между буквой и цифрой. Я хочу, чтобы пользователи могли ввести C1 и сохранить таблицу C0000000001 или C1234, а таблицу сохранить C0000001234.
Я хочу, чтобы ограничение было на жестких данных в таблице. Таблица должна содержать полный идентификатор клиента, но я хочу, чтобы пользователи вводили только букву C и номер клиента при вводе / поиске клиентов. Я использую Access 2010.
Я считаю, что первым символом всегда будет C, но в любом случае это был бы только один альфа-символ, если бы это не было.
Я понимаю, что вы говорите, но большая часть данных (тысячи записей) будет из другой системы, которая хранит их таким образом. Это ограничивает мою погрешность. В противном случае экспорт из другой системы необходимо будет изменить вручную перед импортом в базу данных и наоборот.
Поиск будет производиться только по существующим записям, которые будут сохранены в формате C0000001234, но я хотел бы, чтобы пользователь мог опускать ведущие нули при вводе критериев поиска.
3 ответа
Я предлагаю использовать формы со связанными запросами с помощью функции FORMAT.
Вам нужно уточнить, где вы хотите, чтобы это было реализовано, но я предполагаю, что у вас настроена таблица и вы хотели бы иметь возможность вводить / искать данные из формы.
Я создам одну форму для ввода frmAdd . Для формы ввода я создал запрос, который будет запускаться при нажатии кнопки в форме. Добавьте два текстовых поля newID и newOther в формы, которые не ограничены, но которые пользователь может использовать для ввода данных. Затем запрос извлечет эти данные и добавит их в вашу таблицу в измененном формате. Вот SQL для этого запроса:
Маска ввода не подходит для этого. Маска ввода заставляет пользователя вводить данные определенным образом. Что вам нужно, так это код VBA для запуска в событии AfterUpdate в форме. В таблице нет способа принудительно включить данные в этот шаблон, позволяющий использовать запрошенный вами метод ввода.
Возможно, есть более эффективный способ сделать это, но он работает.
Этот вопрос в сочетании с вашим предыдущим вопросом здесь наводит на мысль, что вы очень стараетесь иметь структуру данных в своем База данных Access точно соответствует устаревшей системе, из которой вы получаете массовые обновления. Это может быть ненужным или даже нежелательным.
Например, вместо того, чтобы поддерживать CustomerId как Text(11) (как в старой системе), вы можете сохранить его в своей базе данных Access как
- CustomerIdPrefix: Text(1) и
- CustomerIdNumber: Long Integer или, возможно, Decimal , если числовая часть действительно может превышать 2 147 483 647
Таблица клиентов в Access также может включать вычисляемое поле с именем CustomerId как
Для поиска ваша форма может иметь текстовое поле для префикса (значение по умолчанию: 'C') и другое текстовое поле для числовой части. Тогда поиск может использовать такое условие, как
Или, если пользователь хочет создать фильтр в форме (или представлении таблицы), вероятно, будет достаточно просто выполнить фильтрацию по числовой части.
Если вам когда-либо требовалось передать информацию обратно в устаревшую систему, вы можете просто экспортировать запрос, который включает вычисляемое поле [CustomerId] (и опускает [CustomerIdPrefix] и [CustomerIdNumber]), и все будет в порядке.
Некоторые символы, используемые для задания маски ввода, приведены в табл. 10.3.
Маска ввода состоит из трех частей, разделенных точкой с запятой. Первая часть представляет собственно маску ввода, состоящую из символов маски и постоянных символов. Необязательная вторая часть указывает системе MS Access, нужно ли сохранять постоянные символы маски в этом поле (0 – постоянные символы маски включаются в значение поля, 1 – сохраняться будут только введенные символы). Необязательным третьим компонентом маски ввода является символ, используемый для указания заполняемых при
Таблица 10.3
Символы маски ввода
В данную позицию должна быть введена цифра; не допускается ввод знаков "плюс" и "минус"
В данную позицию могут быть введены цифра или пробел; не допускается ввод знаков "плюс" и "минус"
В данную позицию могут быть введены цифра, пробел, знак "плюс" или "минус"
В данную позицию должна быть введена произвольная буква
В данную позицию может быть введена буква
В данную позицию должна быть введена буква или цифра
В данную позицию может быть введена буква или цифра
В данную позицию должен быть введен произвольный символ или пробел
Указывает, что следующий символ следует рассматривать в качестве постоянного символа
Управление форматами ввода данных с помощью масок ввода
Вы можете помочь пользователям правильно вводить данные в классические базы данных Access, подключив маски ввода к полям, имеющим строго определенный формат значений, например номера телефонов.
Маска влияет только на ввод значений в Access: она не меняет способ их хранения, который записи от типа данных поля и других свойств. Дополнительные сведения о хранении данных в Access см. в статье Введение в типы данных и свойства полей.
Важно: Эта статья относится только к классическим базам данных Access. Веб-приложения и веб-базы данных Access не поддерживают маски ввода.
В этой статье
Общие сведения о масках ввода
Маска ввода — это строка символов, указывающая формат допустимых значений входных данных. Маски ввода можно использовать в полях таблиц или запросов, а также в элементах управления форм и отчетов. Маска ввода хранится в свойствах объекта.
Маску ввода рекомендуется использовать, когда вводимые значения должны иметь единый формат, например для полей с номерами телефонов из десяти цифр. Если пользователь введет номер, не указав код города, данные не будут приняты в Access, пока пользователь не добавит код города.
Три компонента маски ввода
Маски ввода состоят из одного обязательного и двух необязательных компонентов, разделенных точками с запятой. Назначение каждого из компонентов описано ниже.
Первый компонент является обязательным. Он представляет собой знак или строку (последовательность знаков) маски с заполнителями и литералами, например круглыми скобками, точками и дефисами.
Второй компонент не является обязательным и определяет способ хранения встроенных знаков маски в поле. Если для этого компонента задано значение , знаки сохраняются вместе с данными, а если 1, то знаки отображаются без сохранения. Выбрав значение 1, можно сэкономить место для хранения базы данных.
Третий компонент маски ввода также не является обязательным и определяет знак, используемый в качестве заполнителя. По умолчанию в Access используется знак подчеркивания (_). Чтобы задать другой знак, введите его в третьем компоненте маски.
Пример маски ввода для телефонных номеров в формате России: (999) 000-00-00;0;-:
В маске используются два заполнителя — 9 и 0. Заполнитель 9 обозначает необязательные цифры (код города можно не вводить), а 0 — обязательные.
Значение 0 во втором компоненте маски ввода указывает на то, что знаки маски следует хранить вместе с данными.
Третий компонент маски ввода указывает на то, что вместо знака подчеркивания (_) в качестве заполнителя будет использоваться дефис (—).
Знаки, определяющие маски ввода
В приведенной ниже таблице перечислены заполнители и литералы, используемые в масках ввода, и описано их влияние на ввод данных.
Определение маски ввода
Если свойство Формат (Format) управляет тем, как данные отображаются в поле таблицы, то свойство Маска ввода (Input Mask) позволяет контролировать ввод данных в таблицу. И не только контролировать, но и упрощать процесс ввода. Маску используют в том случае, когда вводимые данные должны содержать определенные символы в некоторых позициях вводимой строки. Самым простым и ярким примером таких данных являются номера телефонов. Маска ввода должна обеспечить возможность вводить только цифры номера, а остальные символы (скобки вокруг кода города, дефис между цифрами номера) будут добавляться автоматически. Маска задается с помощью символов, приведенных в табл. 2.12.
Таблица 2.12. Символы для создания масок ввода
- символьной строки маски;
- символа 0. Это означает, что введенные в поле данные будут сохраняться вместе со специальными символами. Можно заменить 0 на 1 — тогда специальные символы маски не будут запоминаться в поле;
- символа заполнителя.
Как использовать маску ввода в excel vba?
ПРОЧИТАЙТЕ ВНИМАТЕЛЬНО ВОПРОС, ПОЖАЛУЙСТА, ЭТО РЕКОМЕНДАЦИИ EXCEL VBA. NOT EXCEL
Мне была поручена фиксация ввода даты в форме VBA. Текстовое поле должно содержать имя пользователя в виде MM/DD/YYYY .
Мне нужно использовать маску ввода, не разрешено делать что-то как подтверждение даты после или с использованием календаря. До сих пор я мог использовать упомянутые 2 метода (форматирование формата после использования ISDATE ).
Тем не менее, теперь стало ясно, что это должна быть маска, поэтому ключи отфильтровываются при вводе, причем маска отображается при вводе даты: __/__/____
Там, где вы видите символ подчеркивания, он должен иметь возможность вводить числа и всегда находиться на этих позициях
Есть ли способ сделать это? Я могу найти учебник для маски в Access VBA.
input vba excel-vba excel masking
Этот пост может помочь вам.
Использование входной маски
. Вы можете задаться вопросом, есть ли способ настроить маску ввода, которая автоматически добавит двоеточие. Хорошая новость — да, есть. Плохих новостей нет, нет. Звук запутанный? Позволь мне объяснить.
Вы можете настроить пользовательский формат, который отобразит ваше время в любом формате. Например, вы можете использовать следующие шаги:
Теперь вы можете ввести свое время, используя только цифры. Проблема (и это плохая новость) заключается в том, что ячейка действительно не содержит времени. Если вы введете 230 (за 2:30), она не будет содержать 2:30 как раз — она содержит двести тридцать. Таким образом, вы не можете напрямую использовать содержимое ячейки непосредственно во времени.
Чтобы преодолеть это, вы можете использовать другой столбец для отображения введенных цифр, преобразованных во время. Все, что вам нужно сделать, это использовать формулу для преобразования. Например, если введенное время было в ячейке A3 , вы можете использовать следующую формулу в другой ячейке для преобразования:
Отформатируйте ячейку, которая содержит приведенную выше формулу, чтобы отображать один из различных временных форматов, и все вы настроены.
(Полная статья и многое другое в источнике.)
Сводные таблицы Excel
Если вам часто приходится вводить даты и время в ячейки, то вам должна понравиться идея писать их сокращенно, без точек-дробей – просто как число. Чтобы в заданном диапазоне ячеек листа, например, число 250616 после ввода и нажатия клавиши Enter автоматически превращалось в 25.06.2016.
Как в Excel настроить быстрый ввод даты без разделителей
Для реализации такого возможны два варианта.
Первый – использовать функцию преобразования текста в дату ДАТАЗНАЧ (DATEVALUE) и функции извлечения фрагментов из текста ЛЕВСИМВ (LEFT), ПРАВСИМВ (RIGHT) и ПСТР (MID), чтобы разделить шесть введенных чисел по два, добавить к ним точки и составить из них полноценную дату в соседней ячейке.
Для реализации быстрого ввода даты возможны два варианта
В англоязычном варианте: =DATEVALUE(LEFT(D1;2)&”.”&MID(D1;3;2)&”.”&RIGHT(D1;2)) .
Если же хочется выполнять это преобразование прямо в той же ячейке, куда вводятся числа, то без макроса не обойтись. Для этого щелкните по ярлычку листа, куда будут вводиться даты и время, и выберите команду Исходный текст (View Code). В открывшееся окно редактора Visual Basic вставьте следующий код.
Диапазон A2:A10 в коде замените на свою область листа, куда подобным образом собираетесь вводить даты.
Как использовать маску ввода в Excel VBA?
ВНИМАТЕЛЬНО ПРОЧИТАЙТЕ ВОПРОС, ПОЖАЛУЙСТА, ЭТО НАМЕРЕНИЯ ОТЛИЧАЮТ VBA. НЕ ЭКСКАЛЬНО
Мне было дано задание зафиксировать ввод даты в форме VBA. В текстовом поле пользователь должен ввести дату в MM/DD/YYYY .
Я должен использовать маску ввода, не разрешено делать что-либо в качестве даты подтверждения после или с использованием календаря. До сих пор я мог использовать 2 упомянутых метода (форсирование формата после использования ISDATE ).
Однако теперь стало ясно, что это должна быть маска, поэтому ключи фильтруются при вводе, причем маска отображается при вводе даты: __/__/____
Где вы видите подчеркивание, он должен иметь возможность только вводить цифры, и / всегда находятся на этих позициях
Есть ли способ сделать это? Я могу только найти учебник для маски в Access VBA.
Использование маски ввода
Вы можете настроить пользовательский формат, который будет отображать ваше время в любом формате, который вы хотите. Например, вы можете использовать следующие шаги:
Чтобы преодолеть это, вы можете использовать другой столбец для отображения введенных цифр, преобразованных во время. Все, что вам нужно сделать, это использовать формулу, чтобы сделать преобразования. Например, если время, которое вы ввели, было в ячейке A3 , вы можете использовать следующую формулу в другой ячейке, чтобы выполнить преобразование:
Отформатируйте ячейку, содержащую приведенную выше формулу, чтобы она отображала один из различных форматов времени, и все готово.
Читайте также: