![](/logo_grey.gif)
Последние записи
- Проверка на шестнадцатеричный формат записи
- Отдать пользователю файл с помощью file_get_contents()
- Написать собственую функцию operator[] для битов
- Проблема с движением 2D человека
- OpenGl.Создание винтовой лестницы
- Склеить несколько файлов в один
- Windows 10 сменить администратора
- Рандомное слайдшоу
- Событие для произвольной области внутри TImage
- Удаление папки с файлами
![](http://programmersclub.ru/slurm3.jpg)
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
![](http://programmersclub.ru/katajpg.jpg)
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
27th
Мар
Копирование текста в Excel на другой лист с дописыванием
Posted by obzor under VBA
Как можно сделать, чтобы в Excel в одну строку вводились данные (постоянно меняются), а на другом листе выводились эти данные, но когда я меняю на первом листе, чтобы старые данные сохранялись на втором листе, а новые просто дополнялись?
например у меня на листе 1 в ячейка А1: некст (названия лекарств).
лист 2 в ячейке А1: некст
Потом я меняю лекарство получется лист 1 в ячейке А1: ношпа
Лист 2 ячейка А1: некст
Лист 2 ячейка А2: ношпа.
правой кнопкой мыши по ярлыку листа1
исходный текст
копируете в открывшееся окно этот мощный макрос
Private Sub worksheet_change(ByVal Target As Range)
If Target.Address <> "$A$1" Then Exit Sub
Worksheets(2).Cells(Rows.Count, 1).End(xlUp).Offset(1, 0) = Target
End Sub
вернитесь на лист1, вносите данные в А1
в любой удобный Вам момент сохраните потом файл с поддержкой макросов.
Еще вариант. Я это называю выпадающий список с добавлением и сортировкой
Private Sub Worksheet_Change(ByVal Target As Range)
Dim lReply As Long
If Target.Address <> "$A$1" Or IsEmpty(Target) Then Exit Sub
If Target.Column = 1 Then iSheet = "лекарства": IRange = "лекарства"
If WorksheetFunction.CountIf(Worksheets(iSheet).Range(IRange), Target) = 0 Then
lReply = MsgBox("В списке нет лекарства " & Target & ". Добавить?", vbYesNo + vbQuestion)
If lReply = vbYes Then
With Worksheets(iSheet)
.Cells(.Range(IRange).Rows.Count + 1, 1) = Target
'сортировка по возрастанию
.Range(IRange).Sort Key1:=.Range(IRange), Order1:=xlAscending, Header:=xlNo
End With
End If
End If
End Sub
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
![пеллетные котлы](http://programmersclub.ru/respective.jpg)
пеллетные котлы
![пеллетный котел](http://programmersclub.ru/emtas.jpg)
Пеллетный котел Emtas
![форум программистов](http://programmersclub.ru/banf336х280.gif)
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)