Microsoft 365 Ouverture automatique d'un Popup à l'ouverture d'un fichier Excel...

WEIDER

XLDnaute Impliqué
Bonjour à toutes et tous,

Pourriez-vous m'aider à solutionner mon problème, ou plus exactement ma demande ? Perso je suis hélas dépassé par sa complexité...

Tout est expliqué dans mon fichier joint...

Vraiment, mille mercis à tous pour votre aide précieuse !!!

Amicalement

Pascal.
 

Pièces jointes

C

Compte Supprimé 979

Guest
Bonjour Weider,

Pourquoi ne pas mettre la demande dans un 1er temps dans votre post 🤔
Je voudrais qu'en ouvrant mon fichier Excel 'IPP - Suivi', une boite d'alerte s'ouvre au milieu de mon écran m'indiquant les N° d'IPP à traiter, selon.
--> les IPP ayant la date du jour OU une date dépassée (colonne 'O' Date d'application) !
--> ET, ne pas prendre en compte les ligne ayant 'OK' en colonne 'Q' !
Voir l'exemple d'un Popup à droite.

Ensuite pour y répondre, code à mettre dans ThisWorkbook
VB:
Private Sub Workbook_Open()
  ' Appeler la sub pour afficher le popup
  Call PopUp
End Sub

Code à mettre dans un module
Code:
Option Explicit

Sub PopUp()
  Dim dLig As Long, Lig As Long
  Dim Msg As String
  ' Début du message
  Msg = "Attention IPP à traiter !" & vbCr & vbCr
  ' Avec la feuille
  With Sheets("Sommaire IPP")
    ' Dernière ligne remplie
    dLig = .Range("O" & Rows.Count).End(xlUp).Row
    ' Parcourir les lignes
    For Lig = 5 To dLig
      If .Range("O" & Lig).Value = "" Then GoTo SuiteLig
      If .Range("O" & Lig).Value <= Date And .Range("Q" & Lig).Value = "" Then
        Msg = Msg & Range("A" & Lig) & " IPP " & Range("B" & Lig) & " a atteint ou dépassé la date d'application" & vbCr
      End If
SuiteLig:
    Next Lig
  End With
  MsgBox Msg, vbCritical, "ATTENTION IPP A TRAITER..."
End Sub

@+
 

job75

XLDnaute Barbatruc
Bonjour WEIDER, Bruno, chris,

Une autre solution qui utilise une feuille auxiliaire pour afficher le message, le code dans ThisWorkbook :
VB:
Dim F As Worksheet, CelModel As Range 'mémorise les variables

Private Sub Workbook_Open()
Dim c As Range, tablo, i&, flag As Boolean, x$, y$
Set F = Sheets("Message") 'feuille auxiliaire
Set CelModel = F.[H12] 'dont la ligne est masquée
CelModel(2).Resize(F.Rows.Count - CelModel.Row).EntireRow.Delete 'RAZ
Set c = CelModel(2)
F.Visible = xlSheetHidden 'xlSheetVeryHidden
tablo = Sheets("Sommaire IPP").[A5].CurrentRegion.Resize(, 17) 'matrice, plus rapide
For i = 1 To UBound(tablo)
    If IsDate(tablo(i, 6)) And UCase(tablo(i, 17)) <> "OK" Then
        If Date >= tablo(i, 6) Then
            flag = True
            CelModel.MergeArea.Copy c
            x = tablo(i, 1): y = "IPP " & tablo(i, 2)
            c.Replace "xxx", x, xlPart
            c.Replace "yyy", y
            c.Replace "zzz", Format(tablo(i, 6), "dd/mm/yyyy")
            c.Characters(Len(x) + 2, Len(y)).Font.Color = vbRed 'police rouge
            Set c = c(2) 'incrémentation
        End If
    End If
Next
If flag Then Application.OnTime 1, "ThisWorkbook.Affiche" 'exécution différée
End Sub

Sub Affiche()
Dim duree#, t#
duree = 10 'temporisation en secondes, à adapter
Application.ScreenUpdating = False
F.Visible = xlSheetVisible
Application.Goto F.[A1] 'cadrage
CelModel(-1).Select
Application.ScreenUpdating = True
t = Timer + duree
While Timer < t And t < 86400: DoEvents: Wend
F.Visible = xlSheetHidden 'xlSheetVeryHidden
End Sub
A+
 

Pièces jointes

job75

XLDnaute Barbatruc
Si vous ne voulez pas d'une temporisation voyez ce fichier (2) et le bouton Fermer :
VB:
Sub Affiche()
Application.ScreenUpdating = False
F.Visible = xlSheetVisible
Application.Goto F.[A1] 'cadrage
CelModel(-1).Select
End Sub

Sub Ferme()
F.Visible = xlSheetHidden 'xlSheetVeryHidden
End Sub
 

Pièces jointes

Discussions similaires

Réponses
5
Affichages
582
Compte Supprimé 979
C

Statistiques des forums

Discussions
315 294
Messages
2 118 144
Membres
113 436
dernier inscrit
LAROQUE