С Новым годом! Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 17.04.2013
Сообщений: 28
1

Создание макросов методом протоколирования действий

17.04.2013, 20:04. Показов 2724. Ответов 10
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Задание 1. Создание макросов методом протоколирования действий.
Создайте новый документ MS Excel.
а) Режим абсолютной адресации.
Запишите механический макрос Фамилия_1, в результате запуска которого на рабочем листе, начиная с ячейки В2, путем заливки ячеек создаются первые буквы ваших фамилии и имени.
Протестируйте макрос, запуская его на разных листах рабочей книги.
Отредактируйте код макроса так, чтобы буквы стали разного цвета.
Примечание. Рассчитайте количество столбцов для изображения букв. Предусмотрите в макросе команды изменения ширины столбцов.
Сохраните книгу под именем z1_ФИО.xls
Результат выполнения продемонстрируйте преподавателю.
б) Режим относительной адресации.
Запишите механический макрос Фамилия_2, в результате запуска которого на рабочем листе, начиная с активной ячейки, путем заливки ячеек создаются начальные буквы ваших фамилии и имени.
Протестируйте макрос, запуская его из разных ячеек рабочего листа. Отредактируйте код макроса так, чтобы буквы поменялись местами.
Примечание. Предусмотрите в макросе команды изменения ширины столбцов. Ячейки закрашивайте по одной.
Сохраните книгу z1_ФИО.xls
Результат выполнения продемонстрируйте преподавателю.


1-е задание вроде как сделал:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
 Sub fio()
'
' fio Макрос
' asd
'
' Сочетание клавиш: Ctrl+s
'
    Cells.Select
    Selection.ColumnWidth = 2.57
    Range("B2,B3,B4,B5,B6,B6,C4,D3,E2,D5,E6").Select
    Range("E6").Activate
    With Selection.Interior
        .Pattern = xlSolid
        .PatternColorIndex = xlAutomatic
        .Color = vbBlue
        .TintAndShade = 0
        .PatternTintAndShade = 0
    End With
    Range("G6,G5,H5,I5,J5,K5,K6,J5,J4,J3,J2,I2,H3,H2,H4").Select
    Range("H4").Activate
    With Selection.Interior
        .Pattern = xlSolid
        .PatternColorIndex = xlAutomatic
        .Color = vbRed
        .TintAndShade = 0
        .PatternTintAndShade = 0
    End With
    Range("M2,M3,M4,M5,M6,N5,O4,P3,Q2,Q3,Q5,Q4,Q6").Select
    Range("Q6").Activate
    With Selection.Interior
        .Pattern = xlSolid
        .PatternColorIndex = xlAutomatic
        .Color = vbGreen
        .TintAndShade = 0
        .PatternTintAndShade = 0
    End With
End Sub
подскажите как сделать 2-е)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.04.2013, 20:04
Ответы с готовыми решениями:

Создание макросов и их применение
Создайте макрос, который в выделенном диапазоне найдёт количество ячеек с нулевыми значениями. Я в...

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

Создание и преобразование макросов
Здравствуйте! Я создала макросы, затем преобразовала их в процедуры VBA. А дальше не знаю, как...

Создание простых макросов в MS Word
Создайте макрос, который преподносит выделенное число до 3-й степени и заменяет его на результат.

10
0 / 0 / 0
Регистрация: 17.04.2013
Сообщений: 28
01.05.2013, 15:56  [ТС] 2
Неужели на форуме нет человека, который могбы мне помочь?
0
5562 / 1368 / 150
Регистрация: 08.02.2009
Сообщений: 4,109
Записей в блоге: 30
01.05.2013, 18:16 3
Ну почему же нет, вы первый из этих людей! Просто сегодня большие дяди и тёти празднуют 1 Мая.
0
11517 / 3803 / 681
Регистрация: 13.02.2009
Сообщений: 11,223
02.05.2013, 09:14 4
подскажите как сделать 2-е
Ну так в задании же указано как!
методом протоколирования действий
Включай макрорекордер и делай!
В чём проблема-то? не можешь включить?
Сервис-макросы-начать запись
0
0 / 0 / 0
Регистрация: 17.04.2013
Сообщений: 28
02.05.2013, 11:12  [ТС] 5
Вся моя проблема заключается лишь в том, что не полуяается написать инициалы ИМЕННО С АКТИВНОЙ ЯЧЕЙКИ...и только...
0
6975 / 2876 / 552
Регистрация: 19.10.2012
Сообщений: 8,765
02.05.2013, 12:14 6
Сдвиг относительно ячейки - offset
0
0 / 0 / 0
Регистрация: 17.04.2013
Сообщений: 28
03.05.2013, 00:27  [ТС] 7
Не могли бы вы написать макрос хотя бы для одной буквы???? так как "offset" мне ничего не говорит....
0
6975 / 2876 / 552
Регистрация: 19.10.2012
Сообщений: 8,765
03.05.2013, 09:31 8
Редактор VBA - пишем offset, выделяем - F!:
Код
Example
As it applies to the Range object.

This example activates the cell three columns to the right of and three rows down from the active cell on Sheet1.

Worksheets("Sheet1").Activate
ActiveCell.Offset(rowOffset:=3, columnOffset:=3).Activate
				
This example assumes that Sheet1 contains a table that has a header row. The example selects the table, without selecting the header row. The active cell must be somewhere in the table before the example is run.

Set tbl = ActiveCell.CurrentRegion
tbl.Offset(1, 0).Resize(tbl.Rows.Count - 1, _
    tbl.Columns.Count).Select
Ещё можно в гугле поискать. Или на этом форуме

P.S. Это ведь была единственная проблема?

Добавлено через 8 минут
Я бы делал как-то так - закрасил вручную букву, посмотрел какая область нужна, какие ячейки закрашены (номера слева направо, сверху вниз).
Затем через offset и set получил ссылку на такую область (такого размера, в нужном месте), затем через номера ячеек её закрасил кодом.
Аналогично вторая буква.
Закраску вынести в две отдельные процедуры - тогда будет легко поменять эти буквы местами (просто выполняем на области нужную процедуру).
Иначе чтоб поменять их местами - думаю придётся использовать промежуточный диапазон, что некошерно...
1
11517 / 3803 / 681
Регистрация: 13.02.2009
Сообщений: 11,223
03.05.2013, 10:15 9
Цитата Сообщение от dimGo! Посмотреть сообщение
Не могли бы вы написать макрос хотя бы для одной буквы???? так как "offset" мне ничего не говорит....
Для К
Visual Basic
1
2
3
4
5
6
7
8
9
10
Sub Макрос2()
Cells.Interior.ColorIndex = 0
Dim RNG As Range
Set RNG = Selection
Set RNG = Union(RNG, RNG.Offset(1), RNG.Offset(2), RNG.Offset(3), RNG.Offset(4), _
RNG.Offset(2, 1), _
RNG.Offset(1, 2), RNG.Offset(3, 2), _
RNG.Offset(, 3), RNG.Offset(4, 3))
RNG.Interior.Color = vbBlue
End Sub
Добавлено через 14 минут
С учётом совета Hugo121 и требования закраски по одной ячейки можно так:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
Sub Макрос3()
 
Cells.Interior.ColorIndex = 0
'рисуем К от активной
Dim R(): R = Array(1, 2, 3, 4, 2, 1, 3, 0, 4)
Dim C(): C = Array(0, 0, 0, 0, 1, 2, 2, 3, 3)
KRASIT Selection, R, C, vbBlue
 
End Sub
 
Sub KRASIT(N As Range, R, C, COL)
Dim i
N.Interior.Color = COL
For i = 0 To UBound(R)
    N.Offset(R(i), C(i)).Interior.Color = COL
Next i
End Sub
1
6975 / 2876 / 552
Регистрация: 19.10.2012
Сообщений: 8,765
03.05.2013, 12:44 10
Я планировал чуть иначе:
Код
Sub tt()
    Set r = ActiveCell
    Set r1 = Range(r, r.Offset(8, 2))
    Set r2 = Range(r.Offset(, 5), r.Offset(8, 7))

    Call F(r1)
    Call E(r2)

    MsgBox "Теперь поменяем местами..."
    
    Call E(r1)
    Call F(r2)

End Sub

Sub F(rrr)
    Dim el
    rrr.Cells.Interior.ColorIndex = 0
    For Each el In Array(1, 2, 3, 4, 7, 10, 13, 14, 16, 19, 22, 25)
        rrr(el).Interior.Color = vbBlue
    Next
End Sub

Sub E(rrr)
    Dim el
    rrr.Cells.Interior.ColorIndex = 0
    For Each el In Array(1, 2, 3, 4, 7, 10, 13, 14, 16, 19, 22, 25, 26, 27)
        rrr(el).Interior.Color = vbBlue
    Next
End Sub
Добавлено через 1 час 56 минут
Так поинтереснее (и код чуть оптимальнее):


Код
Option Explicit

Declare Sub Sleep Lib "kernel32" (ByVal milliseconds As Long)

Sub tt()
    Dim r As Range, r1 As Range, r2 As Range

    Set r = ActiveCell
    Set r1 = Range(r, r.Offset(8, 2))
    Set r2 = r1.Offset(, 5)

    Call F(r1): Call E(r2)
    MsgBox "Теперь поменяем местами..."
    Call E(r1): Call F(r2)

End Sub

Sub F(rrr As Range)
    Dim el: rrr.Cells.Interior.ColorIndex = 0
    For Each el In Array(1, 2, 3, 4, 7, 10, 13, 14, 16, 19, 22, 25)
        Sleep 50: rrr(el).Interior.Color = vbBlue
    Next
End Sub

Sub E(rrr As Range)
    Dim el: rrr.Cells.Interior.ColorIndex = 0
    For Each el In Array(1, 2, 3, 4, 7, 10, 13, 14, 16, 19, 22, 25, 26, 27)
        Sleep 50: rrr(el).Interior.Color = vbBlue
    Next
End Sub
1
0 / 0 / 0
Регистрация: 17.04.2013
Сообщений: 28
03.05.2013, 14:15  [ТС] 11
всем большое спасибо!!!!!
0
03.05.2013, 14:15
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.05.2013, 14:15
Помогаю со студенческими работами здесь

Строковые переменные, автоматическое создание макросов
По строкам: 7.2 Даны два слова. Найти сколько раз во втором слове встречается первая буква...

Работа с текстовыми строками. Создание макросов в Excel
Есть столбец.В каждой строке этого столбца описана полная характеристика товара. В этом столбце...

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

создание макросов
Здравствуйте ,уважаемые эксперты помогите пожалуйста с реализацией этого:


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru