0 / 0 / 0
Регистрация: 17.04.2013
Сообщений: 28
|
||||||
1 | ||||||
Создание макросов методом протоколирования действий17.04.2013, 20:04. Показов 2724. Ответов 10
Метки нет (Все метки)
Задание 1. Создание макросов методом протоколирования действий.
Создайте новый документ MS Excel. а) Режим абсолютной адресации. Запишите механический макрос Фамилия_1, в результате запуска которого на рабочем листе, начиная с ячейки В2, путем заливки ячеек создаются первые буквы ваших фамилии и имени. Протестируйте макрос, запуская его на разных листах рабочей книги. Отредактируйте код макроса так, чтобы буквы стали разного цвета. Примечание. Рассчитайте количество столбцов для изображения букв. Предусмотрите в макросе команды изменения ширины столбцов. Сохраните книгу под именем z1_ФИО.xls Результат выполнения продемонстрируйте преподавателю. б) Режим относительной адресации. Запишите механический макрос Фамилия_2, в результате запуска которого на рабочем листе, начиная с активной ячейки, путем заливки ячеек создаются начальные буквы ваших фамилии и имени. Протестируйте макрос, запуская его из разных ячеек рабочего листа. Отредактируйте код макроса так, чтобы буквы поменялись местами. Примечание. Предусмотрите в макросе команды изменения ширины столбцов. Ячейки закрашивайте по одной. Сохраните книгу z1_ФИО.xls Результат выполнения продемонстрируйте преподавателю. 1-е задание вроде как сделал:
0
|
17.04.2013, 20:04 | |
Ответы с готовыми решениями:
10
Создание макросов и их применение Изучить создание макросов Создание и преобразование макросов Создание простых макросов в MS Word |
0 / 0 / 0
Регистрация: 17.04.2013
Сообщений: 28
|
|
01.05.2013, 15:56 [ТС] | 2 |
Неужели на форуме нет человека, который могбы мне помочь?
0
|
11517 / 3803 / 681
Регистрация: 13.02.2009
Сообщений: 11,223
|
|
02.05.2013, 09:14 | 4 |
В чём проблема-то? не можешь включить? Сервис-макросы-начать запись
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 | ||||||||||
Для К
С учётом совета Hugo121 и требования закраски по одной ячейки можно так:
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 Так поинтереснее (и код чуть оптимальнее): Код
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 | |
03.05.2013, 14:15 | |
Помогаю со студенческими работами здесь
11
Строковые переменные, автоматическое создание макросов Работа с текстовыми строками. Создание макросов в Excel Создание макросов создание макросов Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи | |||||
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства
Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
|
Что такое NullReferenceException и как исправить?
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-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
|