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 :

Erreur boucle - Foreach information provenant de deux sources [PowerShell]


Sujet :

Scripts/Batch

  1. #1
    Candidat au Club
    Femme Profil pro
    Chargée de projet TI
    Inscrit en
    Avril 2021
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Canada

    Informations professionnelles :
    Activité : Chargée de projet TI
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2021
    Messages : 3
    Par défaut Erreur boucle - Foreach information provenant de deux sources
    Bonjour je travaille sur un script powershell allant chercher des informations machines de l'AD et d'une base de données SQL.
    La majorité des informations provienne de L'AD mais si le nom de la machine est dans l'AD et dans la base de données alors je souhaite mettre le nom du client (qui se trouve associé à la machine dans la base de données) a la colonne client de mon fichier client.
    Toute la partie récupération et traitement des données de l'AD se fait bien mais la partie SQL pause problème. En effet j'ai toujours le même nom de client qui est transmis à toutes mes lignes.
    Je pense que mon problème vient de ma deuxième boucle foreach mais je ne voit pas ou se situe mon erreur.
    Si quelqu'un peux me dire ou mon raisonnement est faux ca m'aiderait.
    merci

    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
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    309
    310
    311
    312
    313
    $properties =
    @(
    'cn',
    'DistinguishedName',
    'Description',
    'OperatingSystem',
    'OperatingSystemVersion',
    'OperatingSystemServicePack'
     
    )
    #Récupérer les données De sccm
     
    Set-Location "SQLSERVER:\SQL\servername\DEFAULT\Databases\xx"
    $SCCMentry = Invoke-Sqlcmd -Query "SELECT [Active0],[AD_Site_Name0],[User_Name0],[Name0],[Netbios_Name0],[Primary_Group_ID0],[User_Account_Control0],[Distinguished_Name0] FROM [CM_PS1].[dbo].[v_R_System] Where User_Account_Control0!=4098 AND (Distinguished_Name0 NOT LIKE '%Labo%') AND (Distinguished_Name0 NOT LIKE '%Kiosk%')  AND (Operating_System_Name_and0 NOT LIKE '%Server%');" 
    cd C:/
     
    # Lancement d'une instance de MS Excel
    $excel = New-Object -ComObject "Excel.Application"            
    #$excel.Visible = $True
    $excel.DisplayAlerts = $False
     
    # Création d'une feuille Excel + activation de la feuille en cours   
    $workbook = $excel.Workbooks.Add()
    $sheet = $workbook.Worksheets.Item(1)
    $sheet.Activate() | Out-Null
     
    # On se positionne en A1 sur Excel (ligne=1/colonne=1)
    # La première ligne corresponddra aux titres des colonnes
    $row = 1
    $Column = 1
     
    # Saisie des données dans Excel
    $sheet.Cells.Item($row,$column)= 'CI CATEGORY'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'CI FOLDER'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
     # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'CI STATE'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ACTIVE'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'MANUAL CI NUMBER'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ENGLISH NAME'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'FRENCH NAME'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ENGLISH DESCRIPTION'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'FRENCH DESCRIPTION'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'CLIENT'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'OWNER'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ENTERPRISE'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
     # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'IMPACTED CIS'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= '0'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= '1'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
     # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= '2'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ 
    # On passe à la colonne suivante
     
    # On passe à la seconde ligne et on revient à la colonne 1 (A2)
    $row = 2
    $Column = 1
    # Récupération des données AD pour les ordinateurs
     
    $entries = Get-ADComputer -properties $properties -Filter {operatingsystem -notlike "*Server*" -and operatingsystem -notlike "*red*" -and userAccountControl -ne 4098} 
    foreach ($entry in $entries){
    $SCCMClient = $NULL
    echo $SCCMClient
    $SCCMClient1 = $NULL
    echo "1 boucle foreach"
     
        if($entries1 = $entry|Where-Object {($_.distinguishedname  -notlike "*OU=Labo..." -and $_.distinguishedname  -notlike "*OU=Kiosk...")}){
            echo "1 boucle if"
         :sccm  Foreach($SCCM in $SCCMentry){
             if(($SCCM.Name0 = $entries1.cn) -and ($SCCM.User_Name0 -ne $NULL)) {
                  $SCCMClient = $SCCM.User_Name0 
                #  echo $SCCMClient
                  $SCCMClient1 = $SCCMClient + "@uqat.ca"
                 #  echo $SCCMClient1
                   break sccm
                  }
             }
        #boucle pour remplir le excell
     
     
                        $sheet.Cells.Item($row,$column) = "Materiels"
                        $column++
     
                        $sheet.Cells.Item($row,$column) = "Ordinateurs"
                        $column++
     
                        $sheet.Cells.Item($row,$column) = "En Production"
                        $column++
     
                        $sheet.Cells.Item($row,$column) = 1
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.cn
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.cn
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.cn
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.Description
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.Description
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $NULL
                        $column++
     
                       $sheet.Cells.Item($row,$column) = $SCCMClient1
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $NULL
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $NULL
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.OperatingSystem
                        $column++
     
     
                        $sheet.Cells.Item($row,$column) = $entries1.OperatingSystemVersion
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.OperatingSystemServicePack
                        $column++
     
                        $row++
                        $column=1
     
     
    }elseif($entries2 =$entry|Where-Object {($_.distinguishedname  -like "*OU=Labo..." -and $_.distinguishedname  -notlike "*OU=Kiosk...")}){
        #boucle pour remplir le excell
     
             $sheet.Cells.Item($row,$column) = "Materiels"
             $column++
     
             $sheet.Cells.Item($row,$column) = "Laboratoire"
             $column++
     
             $sheet.Cells.Item($row,$column) = "En Production"
             $column++
     
             $sheet.Cells.Item($row,$column) = 1
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.OperatingSystem
             $column++
     
     
             $sheet.Cells.Item($row,$column) = $entries2.OperatingSystemVersion
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.OperatingSystemServicePack
             $column++
     
             $row++
             $column=1
     
        }elseif($entries3 =$entry|Where-Object {($_.distinguishedname  -like "*OU=Kiosk...")}){
        #boucle pour remplir le excell
     
             $sheet.Cells.Item($row,$column) = "Materiels"
             $column++
     
             $sheet.Cells.Item($row,$column) = "Kiosk"
             $column++
     
             $sheet.Cells.Item($row,$column) = "En Production"
             $column++
     
             $sheet.Cells.Item($row,$column) = 1
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.OperatingSystem
             $column++
     
     
             $sheet.Cells.Item($row,$column) = $entries3.OperatingSystemVersion
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.OperatingSystemServicePack
             $column++
     
             $row++
             $column=1
        }
     
    }
     
     
    # Optionnel : vous pouvez vouloir sauvegarder le fichier que vous venez de générer
    $path="C:\Users\Ordinateurs"
    $workbook.SaveAs($path,62)
    $workbook.Close
    $excel.Quit()
     
    #################################################
    # END OF PROGRAM
    #################################################

  2. #2
    Candidat au Club
    Femme Profil pro
    Chargée de projet TI
    Inscrit en
    Avril 2021
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Canada

    Informations professionnelles :
    Activité : Chargée de projet TI
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2021
    Messages : 3
    Par défaut trouver l'erreur
    pour ceux que ca intéresse je sais ou est l'erreur même si je n'ai pas encore réussi à trouver comment la contourner.
    l'erreur vient de la deuxieme boucle foreach
    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    :sccm  Foreach($SCCM in $SCCMentry){
             if(($SCCM.Name0 = $entries1.cn) -and ($SCCM.User_Name0 -ne $NULL)) {
                  $SCCMClient = $SCCM.User_Name0 
                #  echo $SCCMClient
                  $SCCMClient1 = $SCCMClient + "@domaine.com"
                 #  echo $SCCMClient1
                   break sccm
                  }
             }
    En effet je trouve la première valeur sans problème mais ensuite cette boucle ne passe pas a la deuxième valeur.
    Elle continue toujours à comparer la première a $entries1.cn
    d'où mon problème.
    Si je trouve une solution je vous tiens au courant.

  3. #3
    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
    :sccm

    OMG mais qu'est ce que c'est ? Pas une étiquette tout de même ?
    Appelé par le Break ca tourne pas en boucle ?

    EDIT : D'après la doc ta commande semble valide : https://docs.microsoft.com/fr-fr/pow...powershell-7.1

  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
    Avec les commandes utilisées sans semble normal puisque une fois que tu as trouvé la première valeur tu lui demande de sortir de la boucle

    Il doit juste y avoir un problème de conception/logique

  5. #5
    Candidat au Club
    Femme Profil pro
    Chargée de projet TI
    Inscrit en
    Avril 2021
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Canada

    Informations professionnelles :
    Activité : Chargée de projet TI
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2021
    Messages : 3
    Par défaut
    Bonjour,
    en effet en utilisant la même logique sur une autre manière de faire j'avais le même problème.
    Après un weekend à me vider la tête j'ai trouver une solution ce matin. Peut être pas la plus élégante ou rapide. Mais elle marche très bien.
    je met le code plus bas si cela peut aider quelqu'un.
    merci d'avoir regardé.

    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
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    $properties =
    @(
    'cn',
    'DistinguishedName',
    'Description',
    'OperatingSystem',
    'OperatingSystemVersion',
    'OperatingSystemServicePack'
     
    )
    #Récupérer les données De sccm
     
    Set-Location "SQLSERVER:\SQL\Server\DEFAULT\Databases\DAta"
    $SCCMentry = Invoke-Sqlcmd -Query "SELECT [Active0],[User_Name0],[Name0],[User_Account_Control0],[Distinguished_Name0] FROM [CM_PS1].[dbo].[v_R_System] Where User_Account_Control0!=4098 AND (Distinguished_Name0 NOT LIKE 'B') AND (Distinguished_Name0 NOT LIKE 'C')  AND (Operating_System_Name_and0 NOT LIKE '%Server%') AND (User_Name0 NOT LIKE '') AND (User_Name0 NOT LIKE 'utilisateur');"
    cd C:/
     
    # Lancement d'une instance de MS Excel
    $excel = New-Object -ComObject "Excel.Application"           
    #$excel.Visible = $True
    $excel.DisplayAlerts = $False
     
    # Création d'une feuille Excel + activation de la feuille en cours  
    $workbook = $excel.Workbooks.Add()
    $sheet = $workbook.Worksheets.Item(1)
    $sheet.Activate() | Out-Null
     
    # On se positionne en A1 sur Excel (ligne=1/colonne=1)
    # La première ligne correspondra aux titres des colonnes
    $row = 1
    $Column = 1
     
    # Saisie des données dans Excel
    $sheet.Cells.Item($row,$column)= 'CI CATEGORY'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'CI FOLDER'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
     # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'CI STATE'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ACTIVE'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'MANUAL CI NUMBER'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ENGLISH NAME'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'FRENCH NAME'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ENGLISH DESCRIPTION'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'FRENCH DESCRIPTION'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'CLIENT'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++ # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'OWNER'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'ENTERPRISE'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
     # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= 'IMPACTED CIS'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= '0'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= '1'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
     # On passe à la colonne suivante
     
    $sheet.Cells.Item($row,$column)= '2'
    $sheet.Cells.Item($row,$column).Font.Bold=$True
    $Column++
    # On passe à la colonne suivante
     
    # On passe à la seconde ligne et on revient à la colonne 1 (A2)
    $row = 2
    $Column = 1
    $b = ($SCCMentry.count)
    # Récupération des données AD pour les ordinateurs
     
    $entries = Get-ADComputer -properties $properties -Filter {operatingsystem -notlike "*Server*" -and operatingsystem -notlike "*red*" -and userAccountControl -ne 4098}
    foreach ($entry in $entries){
    $NOMClient = $NULL
    $SCCMClient1 = $NULL
      echo $SCCMClient1
     
        if($entries1 = $entry|Where-Object {($_.distinguishedname  -notlike "B" -and $_.distinguishedname  -notlike "C")}){
     
        #boucle pour remplir le excell
     
                        $sheet.Cells.Item($row,$column) = "Materiels"
                        $column++
     
                        $sheet.Cells.Item($row,$column) = "Ordinateurs"
                        $column++
     
                        $sheet.Cells.Item($row,$column) = "En Production"
                        $column++
     
                        $sheet.Cells.Item($row,$column) = 1
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.cn
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.cn
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.cn
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.Description
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.Description
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $NULL
                        $column++
     
                        For($SCCM=0; $SCCM -lt $b ;$SCCM++){
                    if($SCCMentry[$SCCM].Name0 -eq $entries1.cn){
                         $Client = $SCCMentry[$SCCM].User_Name0
                         $Client1 = $Client + "@domain.com"
                         $sheet.Cells.Item($row,$column) = $Client1                 
                         }
                    }
     
                $Column++
     
                        $sheet.Cells.Item($row,$column) = $NULL
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $NULL
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.OperatingSystem
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.OperatingSystemVersion
                        $column++
     
                        $sheet.Cells.Item($row,$column) = $entries1.OperatingSystemServicePack
                        $column++
     
                        $row++
                        $column=1
     
                        }
    if($entries2 =$entry|Where-Object {($_.distinguishedname  -like "B" -and $_.distinguishedname  -notlike "C")}){
        #boucle pour remplir le excell
       echo "3 boucle if"
             $sheet.Cells.Item($row,$column) = "Materiels"
             $column++
     
             $sheet.Cells.Item($row,$column) = "Laboratoire"
             $column++
     
             $sheet.Cells.Item($row,$column) = "En Production"
             $column++
     
             $sheet.Cells.Item($row,$column) = 1
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.OperatingSystem
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.OperatingSystemVersion
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries2.OperatingSystemServicePack
             $column++
     
             $row++
             $column=1
     
        }elseif($entries3 =$entry|Where-Object {($_.distinguishedname  -like "C"}){
        #boucle pour remplir le excell
      echo "4 boucle if"
             $sheet.Cells.Item($row,$column) = "Materiels"
             $column++
     
             $sheet.Cells.Item($row,$column) = "Kiosk"
             $column++
     
             $sheet.Cells.Item($row,$column) = "En Production"
             $column++
     
             $sheet.Cells.Item($row,$column) = 1
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.cn
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.Description
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $NULL
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.OperatingSystem
             $column++
     
     
             $sheet.Cells.Item($row,$column) = $entries3.OperatingSystemVersion
             $column++
     
             $sheet.Cells.Item($row,$column) = $entries3.OperatingSystemServicePack
             $column++
     
             $row++
             $column=1
        }
     
    }
     
     
    # Optionnel : vous pouvez vouloir sauvegarder le fichier que vous venez de générer
    $path="C:\Users\Ordinateurs"
    $workbook.SaveAs($path,62)
    $workbook.Close
    $excel.Quit()
     
    #################################################
    # END OF PROGRAM
    #################################################

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 11/12/2020, 11h58
  2. Application de Boucle foreach sur des tables comme source
    Par faten_ dans le forum Approche théorique du décisionnel
    Réponses: 0
    Dernier message: 06/08/2009, 12h38
  3. Comparaison de deux string, boucle foreach
    Par cecile22sky dans le forum C#
    Réponses: 2
    Dernier message: 31/03/2009, 11h12
  4. [MySQL] Erreur boucle while et foreach
    Par tiesto95 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 13/01/2009, 12h01
  5. [JSTL] boucle forEach pour deux liste en même temps
    Par ruud002 dans le forum Taglibs
    Réponses: 1
    Dernier message: 28/09/2006, 15h54

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