Выбрать дату в календареВыбрать дату в календаре

Страницы: 1 2 След.
Защита выпадающего списка от копирования/вставки
 
Всем доброго времени суток!
Код внутри файла вырубает копирование(и вставку) полностью, хотя призван блокировать его лишь в указанных диапазонах :  K1:K3 и G1:G3
Drag and drop работает правильно: везде-да, в указанных-диапазонах нет.
Но почему, так же не работает копирование?

Помогите пожалуйста, я скоро с ума сойду.. в интернете не могу найти ответа...
Защита выпадающего списка от копирования/вставки
 
Друзья, добрый день!
Вы обсудили все, но не мой код =))
Я думала я смогу его поправить, ведь у него всего один косяк.
А в остальном вроде работает.
Защита выпадающего списка от копирования/вставки
 
Цитата
sokol92 написал:
Посмотрите  здесь . И кода не нужно.    
Спасибо, за отклик, помучилась, но сделала. получилось! Однако, дело в том, что после объединения появляется теперь уже 2 столбца, вместо одного. далее этот столбец подлежит копированию в другой файл, где нет лишних столбцов, и получается он не вставится уже туда, верно? Для встави потребуется отедльный пустой столбец =(
Защита выпадающего списка от копирования/вставки
 
Здравсnвтуйте!
Существует проблема по защите ячеек из выпадающего листа от вставки после копирования.
Известно, что при этом слетает сам выпадающий список.
Есть такой макрос, который призван защитить определенные области от вставок , в том числе и от вставки из другого источника.

Косяк макроса в том, что он отключает команду Вставить на всех листах когда речь идет о копировании из внешнего источника.
При копировании внутри самого файла- все работает отлично.

Этот кусок вставляется в ThisWorkbook:
Код
Option Explicit
Private Sub Workbook_Activate()
     'Force the current selection to be selected, triggering the appropriate
     'state of the cut, copy & paste commands
    Call ChkSelection(ActiveSheet)
    Application.CellDragAndDrop = False
End Sub
Private Sub Workbook_BeforeClose(Cancel As Boolean)
     'Re-enable the cut, copy & paste commands
    Call ToggleCutCopyAndPaste(True)
    Application.CellDragAndDrop = True
End Sub
Private Sub Workbook_Deactivate()
     'Re-enable the cut, copy & paste commands
    Call ToggleCutCopyAndPaste(True)
    Application.CellDragAndDrop = True
End Sub
Private Sub Workbook_Open()
     'Force the current selection to be selected, triggering the appropriate
     'state of the cut, copy & paste commands
    Call ChkSelection(ActiveSheet)
    Application.CellDragAndDrop = False
End Sub
Private Sub Workbook_SheetActivate(ByVal Sh As Object)
    Call ChkSelection(Sh)
End Sub
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
     'Toggle the cut, copy & paste commands on selected ranges
    Call ChkSelection(Sh)
End Sub
а этот кусок вставляется в Модуль:
Код
Option Explicit
Public Function InRange(Range1 As Range, Range2 As Range) As Boolean
' Added function to check if Cell is In Range
' returns True if Range1 is within Range2'
Dim InterSectRange As Range
    Set InterSectRange = Application.Intersect(Range1, Range2)
    InRange = Not InterSectRange Is Nothing
    Set InterSectRange = Nothing
End Function
Sub ChkSelection(ByVal Sh As Object)
    'Added Primarily to have one place to set restrictions
    'It also fixes the issue where a cell you don't want to
    'copy/paste from/to is already selected, but you
    'came from a sheet that wasn't protected.
     
    Dim rng As Range
    Set rng = Range(Selection.Address)
 
    Select Case Sh.Name
    Case Is = "Sheet1"
        'Disable copy and paste for anything in column A
        If InRange(rng, Columns("A")) Then
            Call ToggleCutCopyAndPaste(False)
        Else
            Call ToggleCutCopyAndPaste(True)
        End If
 
    Case Is = "Sheet2"
        'Disable copy and paste for anything in range G1 to G20
        If InRange(rng, Range("G1:G20")) Then
            Call ToggleCutCopyAndPaste(False)
        Else
            Call ToggleCutCopyAndPaste(True)
        End If
 
    Case Else
        Call ToggleCutCopyAndPaste(True)
    End Select
 
End Sub
Sub ToggleCutCopyAndPaste(Allow As Boolean)
     'Activate/deactivate cut, copy, paste and pastespecial menu items
    Call EnableMenuItem(21, Allow) ' cut
    Call EnableMenuItem(19, Allow) ' copy
    Call EnableMenuItem(22, Allow) ' paste
    Call EnableMenuItem(755, Allow) ' pastespecial
      
 
     'Drag and Drop Disabled from Original code due to deselecting what has been
     'copied and not allowing paste.  Moved to when workbook opens.
     'Drag and drop will not be allowed for entire workbook.
      
     'Activate/deactivate cut, copy, paste and pastespecial shortcut keys
    With Application
        Select Case Allow
        Case Is = False
            .OnKey "^c", "CutCopyPasteDisabled"
            .OnKey "^v", "CutCopyPasteDisabled"
            .OnKey "^x", "CutCopyPasteDisabled"
            .OnKey "+{DEL}", "CutCopyPasteDisabled"
            .OnKey "^{INSERT}", "CutCopyPasteDisabled"
        Case Is = True
            .OnKey "^c"
            .OnKey "^v"
            .OnKey "^x"
            .OnKey "+{DEL}"
            .OnKey "^{INSERT}"
        End Select
    End With
End Sub
  
Sub EnableMenuItem(ctlId As Integer, Enabled As Boolean)
     'Activate/Deactivate specific menu item
    Dim cBar As CommandBar
    Dim cBarCtrl As CommandBarControl
    For Each cBar In Application.CommandBars
        If cBar.Name <> "Clipboard" Then
            Set cBarCtrl = cBar.FindControl(ID:=ctlId, recursive:=True)
            If Not cBarCtrl Is Nothing Then cBarCtrl.Enabled = Enabled
        End If
    Next
End Sub
  
Sub CutCopyPasteDisabled()
     'Inform user that the functions have been disabled
    MsgBox "Sorry! Cutting, copying and pasting have been disabled for the specified range."
End Sub
Ограничение доступа на запуск макроса
 
Цитата
ocet p написал:
А может так
Супер крутяк!
Ограничение доступа на запуск макроса
 
Цитата
БМВ написал:
Range.Find
Здесь к сожалению, ругается на Find.
Ограничение доступа на запуск макроса
 
Здравствуйте!

Есть список людей, которые могут запускать макрос.
Уже есть код, но у меня вопрос, есть ли красивое решение ссылающееся на диапазон? вместо прописания всех ячеек.. как у меня
Список юзеров прописан в ячейках H1:H10 листе md
Код
If Environ("Username") <> Sheets("md").Range("H1") Or Environ("Username") <> Sheets("md").Range("H2") Then
MsgBox "You do not have permission to run this Script", , "Warning!!!"
End
End If
Персонализация письма в VBA
 
Вариант с кавычками пробовала, оказался не рабочим, - не выводил весь текст
Персонализация письма в VBA
 
ocet p, Вы знаете, это круто!
Оно сработало!
Персонализация письма в VBA
 
Niko.x87, спасибо большое, но это не помогло)
У вас классный код, но он сильно не похож на мой(

pantel1987, тоже не сработало((
Персонализация письма в VBA
 
Здравствуйте!

У меня уже есть макрос, который высылает эксель файл адресату из ячейки. Только мне хотелось бы в обращении указать имя получателя, опять таки из ячейки из самого файла. Чтоб обращение не было безликим.

Вот код, хотелось бы после слова Добрый вечер, вставить имя из ячейки D2 Sheets("Main")
Код
Dim OutApp As Object
   Dim OutMail As Object
   Dim xOutMsg As String
   Dim Recipient As Range
   
   On Error Resume Next
   
   Set OutApp = CreateObject("Outlook.Application")
   Set OutMail = OutApp.CreateItem(0)
   With OutMail
   .Display
   End With
 
   Recipient = Sheets("Main").Range(D2).Value
   xOutMsg = "<p style='font-family:ARIAL;font-size:22'><b>Добрый день,  </b><br/>Прошу рассмотреть мою заявку на заказ в приложении.</p>"
   Signature = OutMail.HTMLBody
   
   With OutMail
       .To = Sheets("Main").Cells(2, 4).Value & ";" & Sheets("md").Cells(1, 10).Value 'адрес получателя
       .Subject = "Ответ: Заявка на заказ " & ActiveWorkbook.Sheets("md").Cells(5, 10) & "_" & TekData 'тема письма
       .HTMLBody = xOutMsg & Signature    'текст письма Sheets("md").Cells(3, 10).Value
       .Attachments.Add ActiveWorkbook.FullName
       .Display
   End With
   'With OutMail
   '.send
   'End With
   

   On Error GoTo 0
   Set OutMail = Nothing
   Set OutApp = Nothing
   Application.ScreenUpdating = Tru
'ActiveWorkbook.Close
End Sub

Я сделала вот так:  
Код
xOutMsg = "<p style='font-family:ARIAL;font-size:22'><b>Добрый день, & Recipient & </b><br/>Прошу рассмотреть мою заявку на заказ в приложении.</p>"

Но это просто выдало слово реципиент как текст((
И понятно, ведь OutMsg - задан как строка.
Изменено: Salta-301 - 14.05.2020 21:08:43
Требуется Макрос по переносу данных из одного файла в два разных
 
Цитата
Oleg Boyaroff написал:
Вы готовы предоставить удаленный доступ по RDP для изучения?
Здравствуйте!
Я могу предоставить доступ по обзору, но не по управлению. На корпоративных компах это все ограничено.
Да, можно открыть онлайн версию экселя, либо правой кнопкой и выбрать открыть эксель.
Открытый эксель файл постоянно сохраняется (синх-я) с share point.
Требуется Макрос по переносу данных из одного файла в два разных
 
Пааа-мааа-гии-теее!!! Спа-сииии-теее!!!!!!!
Требуется Макрос по переносу данных из одного файла в два разных
 
Сборные файлы должны находиться на Shared point....
Требуется Макрос по переносу данных из одного файла в два разных
 
Доброго всем дня!
Требуется макрос, который по признаку в опред. колонке переносил бы ( и соответственно, сохранял) данные в один, либо в другой сборный файл.
Сборный файл находится на shared point.
Макрос должен определять последнюю пустую строку в сборочных файлах, и вставить начиная с нее.
Надеюсь понятно.
Какие могут быть сложности с работой макроса в Shared point?
Требуется Макрос по вставлению формул, Путем определения последней строки в таблице.
 
Цитата
Юрий М написал:
Вставление )))
Ради Вас: "по вставке"
Требуется Макрос по вставлению формул, Путем определения последней строки в таблице.
 
Доброго дня!
Есть некая таблица данных в которой несколько столбцов- это формулы.
Из-за того, что строк довольно не мало (1500) файл в общей сложности весит 17 мб.
Во избежание этого(тяжести файла) хочу макрос, который будет определять последнюю строку, и вставлять в эти рейнджи формулы..(в каждый столбец своя формула)
Вставлять естественно значениями.
Есть аналогичный файл, с макросом, который настроен извлекать последнюю строку из сводной таблицы, но он вставляет формулы путем копирования с уже прописанных ячеек.
И на обычную таблицу этот макрос не сработал.
Жду ваших предложений и советов.  
Сводная таблица. Сортировка по Grand total при наличии 2 и более полей в блоке
 
Цитата
Андрей VG написал:
Поэтому, если нужно именно так, и никак иначе, то тогда Через Power Query. Table.Pivot по месяцам и добавляем столбец помесячных сумм (Grand Total)
Спасибо за разъяснение! =)
Сводная таблица. Сортировка по Grand total при наличии 2 и более полей в блоке
 
Добрый день, помогите отсортировать строки значениям в колонке Grand Total, если имеется 2 и более полей в блоке Строки в сводной таблице.
Проблема в том, что при использовании сортировки в More Options- он сортирует внутри выбранного поля.
Например, в строках есть такие поля как департамент, отдел, сотрудник и , а по столбцам идут месяцы.
в значениях у нас к примеру деньги, кто сколько сдал.
И вот есть у нас столбец Grand total и по нему нужно отсортировать, чтоб он не сортировал внутри департамента, а потом внутри отдела и далее.
В данный момент эксель так и делает, и у меня в колонке Grand Total- сплошной хаос.
Нажатие правой кнопкой и сортировка внутри столбца- не приводит ни к каким изменениям вообще.
Макрос для отправки таблицы в "Базу" на Sharepointe
 
Доброго дня, светлейшие умы экселя!
Прошу помочь
На Sharepointe существует база данных по заказам клиентов.
В данный момент она пополняется вручную. Копи\Паст. А именно, к сотруднику прилетает письмо, с вложением эксель шаблона.
Он его открывает и переносит в файл.

Внимание вопрос:
Можно ли встроить в шаблон макрос(или какую-нибудь другую силу небесную), чтоб файл с компьютера отправителя сам залетал в "Базу" которая повторюсь находится на sharepoint.

Вариант доступа в базу для всех прошу не предлагать. А так же создание Базы в интранете тоже не предлагать.. Это слишком большие деньги.
Привязка текста к концу сводной таблицы?
 
Цитата
Андрей VG написал:
Доброе время суток.Как вариант.Успехов.
Андрей, доброго дня!
Вот вы и мне помогли, сами того не подозревая))
А я еще осмелюсь спросить, а есть у вас в рукаве макрос который еще и по столбцам корректирует?
(Наглость- второе счатсье)   :)))))
Наложение сводных таблиц
 
Отлично! Ссылка помогла, но плюс, еще вопрос а можно то же самое только плюс с корректировкой столбцов?   =)))

Цитата
Настя_Nastya написал: доброе утро! У Вас динамическое количество строк?
да
Наложение сводных таблиц
 
Доброго дня всем,

Осмелюсь побеспокоить вас вопросом о том, как избежать наложения нескольких пивотов (сводных) один на другой при фильтрации (увеличении количества строк) если они находятся на одном листе.
Уже прошерстила весь иностр контент и нашла только один сомнительный вариант: определить динамический рейндж для пустых ячеек, и записать макрос на обновление пивота по удаление всей строки в рамках динамического рейнджа.

Само определение пустого динамического поля выглядело так:
Код
=Sheet2!$A$9:INDEX(Sheet2!$A:$A,MATCH("Grand Total",Sheet2!$A:$A,0)+1)

а макрос предложен такой
Код
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    Cells.EntireRow.Hidden = False
    Range("theGap").EntireRow.Hidden = True
End Sub

Но, увы! Не работает!

Прошу помочь! Советы из серии размести пивоты по разным страницам- не принимаются.
Задача в Power Query
 
TZ
Задача в Power Query
 
Доброго всем дня!
ТЗ переделала, теперь оно вполне выполнимое.
Задача актуальная, ждёт своего героя!!!  =)
Макса Зеленского уже и не мечтаю дождаться   =) Отца нашего кода
Задача в Power Query
 
Цитата
Jack Famous написал:
Salta-301 , я в PQ не силён - если интересно решение на макросах, то пишите
К сожалению, интересует только решение в PQ
Доработка в Power query
 
Задача решена, поршу закрыть темку.
Доработка в Power query
 
Цитата
Александр написал:
Вроде было срочно, а ответа так и не поступил
Пишу вам в личку. Доработала ТЗ. Теперь задача- выолпнима.  =))
Задача в Power Query
 
Цитата
TheBestOfTheBest написал:
Пришлите файл на почту, взглянуть на шедевр..
Обязательно пришлю, но сначала причешу ТЗ, ато вдруг и вы откажетесь((
Задача в Power Query
 
Цитата
Андрей VG написал:
Третий, если правильно понимаю - это Зеленский. Хотя он начинал там работу. А у меня компетенций в той области знаний, что требуется  Salta-301 , с комариный нос... Потому и отказался, хотя человек она не вредный и хороший.
Спасибо большое, Андрей, за теплый отзыв  обо мне!
Да, действительно третий отказавшийся это Максим Зеленский, он поначалу взялся, но потом на работе случился завал.

Постараюсь все -таки сделать супер детальное ТЗ видимо в чем-то и моё простое ТЗ виновато(((((((
Страницы: 1 2 След.
Наверх