IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Scripts/Batch Discussion :

Utilisation d'Excel en tâche planifiée [PowerShell]


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de crashyear
    Homme Profil pro
    Responsable d’exploitation informatique
    Inscrit en
    Janvier 2006
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Responsable d’exploitation informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2006
    Messages : 267
    Par défaut Utilisation d'Excel en tâche planifiée
    Bonjour,
    Je suis sur que cette question a déjà été posée, mais je ne retrouve pas de post sur le site.
    J'ai fait un script powershell, quand je le lance "à la main" mon fichier Excel est correctement généré pas de soucis, mais après l'avoir encapsulé dans une tâche planifié, cela ne fonctionne plus...
    Voici mon code :
    Code PowerShell : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    $log = "E:\infoBaL.log"
    (Get-Date).ToString("dd/MM/yyyy - hh:mm:ss") > $log
    "--- Début du script ---" >> $log 
    "Initialisation des variables..." >> $log
     
    $expediteur = "moi@moi.fr"
    $destinataire = "moi@moi.fr"
    $serveur = "monserveur.de.mail"
    $objetmail = "Info boites mail "
    $texte = "Bonjour, `n Voici les informations sur les boîtes mails (voir fichier en PJ). `n Bonne journée ! "
    $objet = $objetmail + " - " + (Get-Date).ToString("dd/MM/yyyy")
     
    #init date et fichier de sorti
    $dateTxt = (Get-Date).ToString("yyyyMMdd")
    $fichier = "E:\infoBaL_"+$dateTxt+".xlsx"
     
     
    (Get-Date).ToString("dd/MM/yyyy - hh:mm:ss") >> $log
    "Début de construction du fichier Excel..." >> $log 
     
    # constrcution d'un excel
    $excel = new-object -comobject Excel.Application 
    $excel.visible = $False
    $excel.DisplayAlerts = $False
     
    #création d'une feuille dans excel
    $work = $excel.Workbooks.Add()
    $workbook = $work.Worksheets.Item(1)
    $work.SaveAs($fichier)
    $work >> $log
     
    # creation des entetes de colonnes
    $workbook.Cells.Item(1,1) = 'Nom - Prenom'
    $workbook.Cells.Item(1,1).Font.Bold=$True
    $workbook.Cells.Item(1,1).Interior.ColorIndex = 23
    $workbook.Cells.Item(1,2) = 'Mail'
    $workbook.Cells.Item(1,2).Font.Bold=$True
    $workbook.Cells.Item(1,2).Interior.ColorIndex = 23
    $workbook.Cells.Item(1,3) = 'Total Size (MB)'
    $workbook.Cells.Item(1,3).Font.Bold=$True
    $workbook.Cells.Item(1,3).Interior.ColorIndex = 23
    $workbook.Cells.Item(1,4) = 'Quota (MB)'
    $workbook.Cells.Item(1,4).Font.Bold=$True
    $workbook.Cells.Item(1,4).Interior.ColorIndex = 23
    $workbook.Cells.Item(1,5) = 'Utilisation (%)'
    $workbook.Cells.Item(1,5).Font.Bold=$True
    $workbook.Cells.Item(1,5).Interior.ColorIndex = 23
    $row=2
     
     
    #creation du tableau de test avec entete (et initialisation a 0 donc increment de 1 du compteur juste apres):
    $table = ,@(0, 'Nom Prenom', 'Mail', 'Total Size (MB)', 'Quota')
    $table_cpt ++
     
     
    (Get-Date).ToString("dd/MM/yyyy - hh:mm:ss") >> $log
    "Entete de fichier Excel terminé." >> $log 
    " --- MailBox CODIR elargi ---" >> $log
    "Recupération des mailbox puis parcours et insertion dans le fichier Excel..." >> $log
     
    #recuperation de la liste des BaL :
    $listeBal= Get-Content ("E:\ListeBaL.20200320.txt")
     
    #parcours de BaL 
    foreach($bal in $listeBal) 
    { 
     # Write-Host $bal 
     $mailbox = Get-Mailbox -Identity $bal
     $table += ,@($table_cpt, $mailbox.Name, $bal, (Get-MailboxStatistics $bal).TotalItemSize.Value.ToMB(), $mailbox.ProhibitSendQuota)
     $table_cpt ++
     
     #insertion Excel
     $col=1
      $workbook.Cells.Item($row,$col)=$mailbox.Name
     $col=2
      $workbook.Cells.Item($row,$col)=$bal
     $col=3
      $size = (Get-MailboxStatistics $bal).TotalItemSize.Value.ToMB()
      $workbook.Cells.Item($row,$col)=$size
     $col=4
     
     $quota = $mailbox.ProhibitSendQuota.Split(" ")
     if($quota[1] -eq "GB")
     {
       $quotaMB=($quota[0] -as [float])*1024
     }
     else
     {
       $quotaMB=$quota[0]
     }
     $workbook.Cells.Item($row,$col)=$quotaMB
     
     $col=5
      $utilisation=($size -as [float])*100/($quotaMB -as [float])
      $workbook.Cells.Item($row,$col)=$utilisation
      if( $utilisation -ge 75)
      {
        $workbook.Cells.Item($row,$col).Interior.ColorIndex = 3
      }
     #Ecriture dans le fichier de log de la BaL traitée
     $mailbox.Name + " : " + $bal >> $log
     (Get-Date).ToString("dd/MM/yyyy - hh:mm:ss") >> $log
     
     $row ++
     
    }
     
     
    $work.Save()
    $work.Close()
    $excel.Quit()
     
    (Get-Date).ToString("dd/MM/yyyy - hh:mm:ss") >> $log
    "Fin d'insertion dans le fichier Excel." >> $log
     
    # tests d'affichage du resultat :
    $table | Out-GridView
    # 
    # foreach($ligne in $table)
    # {
    #   Write-host ($ligne)
    # }
    # 
    # $table | Export-csv -path $fichier
    # INFO : l'export-csv du $table ne fonctionne pas...
     
    (Get-Date).ToString("dd/MM/yyyy - hh:mm:ss") >> $log
    "Envoi email..." >> $log
     
     
      $message = new-object System.Net.Mail.MailMessage $expediteur, $destinataire, $objet, $texte
      $client = new-object System.Net.Mail.SmtpClient $serveur
      $attachment = new-object System.Net.Mail.Attachment $fichier 
      $message.Attachments.Add($attachment)
      $client.Send($message)
     
     
    (Get-Date).ToString("dd/MM/yyyy - hh:mm:ss") >> $log
    "--- FIN ---" >> $log

  2. #2
    Expert confirmé

    Homme Profil pro
    Responsable déploiement (SCCM, InTune, GPO)
    Inscrit en
    Juillet 2014
    Messages
    3 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Responsable déploiement (SCCM, InTune, GPO)
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2014
    Messages : 3 218
    Par défaut
    Problème un problème de contexte.
    Ton compte (SYSTEM ?) qui exécute ton script a bien Excel ?

  3. #3
    Membre éclairé Avatar de crashyear
    Homme Profil pro
    Responsable d’exploitation informatique
    Inscrit en
    Janvier 2006
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Responsable d’exploitation informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2006
    Messages : 267
    Par défaut
    Bonjour,
    Oui, le compte qui exécute la tâche planifiée a Excel, il a aussi les droits sur le répertoire, et lorsque j'exécute le script depuis la session de ce compte, cela fonctionne bien, mais pas au travers de la tâche planifiée...

  4. #4
    Expert confirmé

    Homme Profil pro
    Responsable déploiement (SCCM, InTune, GPO)
    Inscrit en
    Juillet 2014
    Messages
    3 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Responsable déploiement (SCCM, InTune, GPO)
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2014
    Messages : 3 218
    Par défaut
    Ok.

    Je vois qu'il y à un log qui peux t'aider à savoir ou ça bloque

    Tu a ceci aussi qui n'est pas terrible dans une tache planifiée : $table | Out-GridView

  5. #5
    Membre éclairé Avatar de crashyear
    Homme Profil pro
    Responsable d’exploitation informatique
    Inscrit en
    Janvier 2006
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Responsable d’exploitation informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2006
    Messages : 267
    Par défaut Contournement de solution
    Bonjour,
    J'ai trouvé une autre méthode pour générer mon fichier Excel.
    Je suis parti du principe que l'ouverture d'excel ne fonctionnait pas au travers de ma tâche planifiée (j'ai lu ça sur le web) donc voilà comment j'ai fait :
    Code PowerShell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    #déclaration d'un tableau
    $report = @()
    ...
    #parcours de BaL pour alimenter le tableau
    foreach($bal in $listeBal) 
    { 
    ...
     $info = "" | select Nom, Mail, Taille, Quota, Utilisation
     $info.Nom = $mailbox.Name
     $info.Mail = $bal
     $info.Taille = $size
     $info.Quota = $quotaMB
     $info.Utilisation = $utilisation
     # $info >> $log
     $report += $info
    ...
    }
    #Fin du foreach
     
    # Création Excel V2
    $report | Export-excel -Path $xlfile -WorksheetName RecapBAL -AutoSize -AutoFilter -BoldTopRow >> $log
     
    #changement de méthode d'envoi du mail aussi (mais pas forcement necessaire)
    Send-MailMessage -SmtpServer "monserveur.de.mail" -to "$destinataire" -from "$expediteur" -Subject "$objet" -body "$texte" -BodyAsHtml -Attachments "$xlfile"

    Si cela peut aider quelqu'un un jour...
    Sinon, je ne sais pas comment améliorer le format de sorti de mon nouvel Excel, j'aurais aimé y mettre un peu de couleur (et notamment une mise en forme conditionnelle sur mon %d'utilisation), est-ce que quelqu'un sait ?

  6. #6
    Expert confirmé

    Homme Profil pro
    Responsable déploiement (SCCM, InTune, GPO)
    Inscrit en
    Juillet 2014
    Messages
    3 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Responsable déploiement (SCCM, InTune, GPO)
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2014
    Messages : 3 218
    Par défaut
    Il vient d’où Export-excel ?

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Conseil d'utilisation (tâches planifiées)
    Par BuzzLeclaire dans le forum Langage
    Réponses: 13
    Dernier message: 19/05/2009, 22h53
  2. Utilisation fonction excel dans ACCESS: Ereur de compilation
    Par mat_lefebvre dans le forum Access
    Réponses: 2
    Dernier message: 22/03/2006, 10h44
  3. Utilisation d'Excell depuis la MFC
    Par bobirem dans le forum MFC
    Réponses: 5
    Dernier message: 04/03/2006, 11h04
  4. Tâches planifiées
    Par Furius dans le forum Windows XP
    Réponses: 10
    Dernier message: 02/12/2005, 14h58
  5. [D7] Paramétrage tâches planifiées de Windows
    Par Crownless dans le forum API, COM et SDKs
    Réponses: 2
    Dernier message: 18/08/2005, 21h33

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo