Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
15th
Янв
Запретить ввод пробелов в ячейки Excel
Posted by obzor under VBA
При работе в Экселе случайно кладут журнал на клавишу пробела, при этом в незащищенных ячейках вставляется пробел или много пробелов, эти ячейки зависимые, и все рушится в конечных результатах. А обнаружить пробел в ячейке достаточно сложно.
На один-два-три пробела я сделал условное форматирование — изменение цвета, но не помогает, когда пробелов много.
Как запретить ввод пробела(-ов) в определенном массиве ячеек, (они для ввода цифр)?
положите этот макрос
Private Sub Worksheet_Change(ByVal Target As Range)
Dim rg As Range, c As Range
Set rg = Intersect(Target, [b:b])
If rg Is Nothing Then Exit Sub
Application.EnableEvents = False
For Each c In rg
c = Replace(c, " ", "")
Next
Application.EnableEvents = True
End Sub
в модуль листа
будут запрещены пробелы в колонке В
IgorGO, Ваш макрос будет устранять все пробелы в диапазоне.
Понял так, что человек хочет устранять только случайно введёные в ячейку пробелы.
Задачу бы решал как-то так (для частного листа конкретной книги):
Private Sub WorkSheet_Change(ByVal Target As Range)
If Target.Count > 1 Then Exit Sub
If Len(Target.Formula) = 0 Then Exit Sub
Dim Probel As Boolean, iSimv%
Probel = True
For iSimv = 1 To Len(Target.Formula)
If Mid(Target.Formula, iSimv, 1) <> " " Then
'Debug.Print Mid(Target.Formula, iSimv)
Probel = False: Exit For
End If
Next iSimv
If Probel Then
Application.EnableEvents = False
Target.Formula = ""
Application.EnableEvents = True
End If
End Sub
Но подозреваю, что ожидается решение для всех листов и даже всех книг.
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)