|
|
|
Сводные таблицы через VBA
|
|||
|---|---|---|---|
|
#18+
при создании сводной таблицы посредством VBA у меня закрывается доступ к работе со срезами. Использую Excel2016. Пример во вложении. код макроса: Option Explicit Sub addTab() Dim rRange As Range Dim WshData As Worksheet Dim WshPiv As Worksheet Dim Pivot As PivotTable Set WshData = ActiveWorkbook.Sheets("Data") Set WshPiv = ActiveWorkbook.Sheets("Свод") WshData.Activate 'Указать диапазон для сводной таблицы Set rRange = Application.InputBox(Prompt:="Введите диапазон значений", _ Title:="Ввод данных", _ Default:=Range(Cells(ActiveCell.End(xlUp).Row, _ ActiveCell.End(xlToLeft).Column), _ Cells(ActiveCell.End(xlDown).Row, _ ActiveCell.End(xlToRight).Column)).Address, Type:=8) 'создать своздную таблицу Set Pivot = PT(WshData, WshPiv, rRange, "A1") 'задать поля и строки сводной таблицы Pivot.AddFields RowFields:=Array("Категория оборудования", _ "Название оборудования"), ColumnFields:="Регион", _ PageFields:="Рынок сбыта" With Pivot.PivotFields("Доход") .Orientation = xlDataField .Function = xlSum .Position = 1 .NumberFormat = "# #### ##0" .Name = "Доход " End With End Sub Public Function PT(WSD As Worksheet, WSPT As Worksheet, _ DataTable As Range, CellAddress As String) As PivotTable Dim PTCache As PivotCache 'удаление сводных таблиц For Each PT In WSPT.PivotTables PT.TableRange2.Clear Next 'Создание кэша и сводной таблицы WSD.Activate Set PTCache = ActiveWorkbook.PivotCaches.Add _ (SourceType:=xlDatabase, SourceData:=DataTable.Address) Set PT = PTCache.CreatePivotTable(TableDestination:=WSPT.Range(CellAddress), _ TableName:="Сводная таблица") 'PTCache = Nothing End Function Прошу помочь ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 06.01.2017, 13:56 |
|
||
|
|

start [/forum/topic.php?fid=16&fpage=24&tid=1340528]: |
0ms |
get settings: |
5ms |
get forum list: |
11ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
50ms |
get topic data: |
8ms |
get forum data: |
2ms |
get page messages: |
19ms |
get tp. blocked users: |
1ms |
| others: | 208ms |
| total: | 308ms |

| 0 / 0 |
