« PowerShell/Fichier » : différence entre les versions

Aller à la navigation Aller à la recherche
 
(12 versions intermédiaires par le même utilisateur non affichées)
Ligne 11 : Ligne 11 :


== Script de suppression de fichier ==
== Script de suppression de fichier ==
=== Suppression des fichiers anciens ===
<source>
<#
Description : suppression des fichiers dont la date de création est ancienne
Usage      : exécution du script via une tâche planifiée
Auteur      : PHP
Version    : 1.0
Révisions  :
- 1.0 (05/05/2023) : création du script
#>
$FichierAnciennete = -30
$Dossier = "C:\log"
Get-ChildItem $Dossier -Recurse | Where CreationTime -lt (Get-Date).AddDays($FichierAnciennete) | Remove-Item -Force -Recurse
</source>
=== Exemple ===
<source>
<source>
# Auteur : Ph. Page
# Auteur : Ph. Page
Ligne 31 : Ligne 49 :
Write-host $CheminListe -Separator "`n"
Write-host $CheminListe -Separator "`n"


$Reponse = Read-Host "`nEtes-vous sûr cette action ? (O/N)"
$Reponse = Read-Host "`nEtes-vous sûr de cette action ? (O/N)"
if ($reponse -eq "O") {
if ($reponse -eq "O") {
     Write-Host "`n==> Traitement lancé..."
     Write-Host "`n==> Traitement lancé..."
Ligne 60 : Ligne 78 :
* <source inline>Get-ChildItem -file *.* -recurse | sort Length -descending | select -first 10 | Select-Object -property Name, @{Label="Mo";Expression={"{0:N3}" -f ($_.Length / 1MB)}}</source>
* <source inline>Get-ChildItem -file *.* -recurse | sort Length -descending | select -first 10 | Select-Object -property Name, @{Label="Mo";Expression={"{0:N3}" -f ($_.Length / 1MB)}}</source>


== Script de liste (fichier, dossier...) ==
=== Liste de dossiers, nombre de fichier et taille ===
Ce script génère un tableau des dossiers, nombre de fichiers et taille totale, avec tri du plus grand au plus petit.
<source>
Clear-Host
$DossierSource = 'C:\Support'
# Ne liste que les dossiers de premier niveau
$DossierListe = Get-ChildItem -Directory -Path $DossierSource -Depth 0
$DossierListe |
ForEach-Object {
    $Dossier = $_.FullName
    $FichierNombre = (Get-ChildItem -Path $Dossier -Recurse -File).count
    $Taille = (Get-ChildItem -Path $Dossier -Recurse -File | Measure-Object -Property Length -Sum).Sum
    $Rapport = $Taille/($FichierNombre + 1)
    [pscustomobject]@{
        Répertoire    = $Dossier
        Nombre_fichier = $FichierNombre
        Taille_MB      = '{0:N2}' -f ($Taille/1MB)
        Taille_GB      = '{0:N2}' -f ($Taille/1GB)
        Rapport_MB    = '{0:N2}' -f ($Rapport/1MB)
    }
} |
Sort-Object Rapport_MB -Descending |
FT
#| Export-CSV -Path C:\support\raccourcis-liste-20230403.csv -Delimiter ";"
</source>
=== Liste de fichiers en fonction de l'extension, de la taille ===
<source>
$DossierTravail = "C:\php\"
#$filtre = @(".jpg",".jpeg") # filtre pour les images au format jpg
$filtre = @(".mp4",".mov") # filtre pour les vidéos
$tailleMinimum = "2000000" # en octet (2000000 pour 2 Mo)
$ancienneteAnnee = "2023" # jusque l'année indiquée
Clear-Host
Set-Location $DossierTravail
Write-Output "Début du traitement..."
$FichierListe = Get-ChildItem -Recurse | Where-Object { ($_.Extension -in $filtre) -and ($_.Length -ge $tailleMinimum) -and ($_.CreationTime.Year -le $ancienneteAnnee) } | FT name, Length, LastWriteTime, Directory
Write-Output "Fin du traitement"
$FichierListe
</source>
== Script de suppression de fichiers temporaires sur profil itinérant ==
<source>
$Compte = "martinp"
$DossierListe = @(
    "C:\Users\$Compte\AppData\Local\Microsoft\Edge\User Data\Default\Cache\Cache_Data\",
    "C:\Users\$Compte\AppData\LocalLow\Adobe\Acrobat\DC\ConnectorIcons\"
    "C:\Users\$Compte\AppData\Local\Microsoft\Windows\INetCache\Content.Outlook\",
    "C:\Users\$Compte\AppData\Local\Microsoft\Edge\User Data\Default\Service Worker\CacheStorage\"
)
foreach ($Dossier in $dossierliste) {
    Get-ChildItem -path $Dossier -exclude "index"
    $FichierNombre = (Get-ChildItem -Path $Dossier -Recurse -File -include "*.pdf").count
    $Taille = (Get-ChildItem -Path $Dossier -Recurse -File -include "*.pdf" | Measure-Object -Property Length -Sum).Sum
    $TotalTaille = $TotalTaille + $Taille
}
$TotalTaille_MB      = '{0:N2}' -f ($TotalTaille/1MB)
write-host
write-host "=== Bilan ==="
write-host "Nombre de dossier racine :", $DossierListe
write-host "Nombre de dossier racine :", $DossierListe.Count
write-host "Nombre de fichiers :", $FichierNombre
write-host "Taille totale (Mo) :", $TotalTaille_MB
# exemples
# Get-ChildItem -Path "C:\" -Recurse -File -include "*.pdf"
</source>
== Traitement de fichier CSV ==
Vidéo Youtube, TechSckool, CSV File Handling with PowerShell :
* vidéo : https://www.youtube.com/watch?v=u5ML8VVKgi0
* github : https://github.com/TechSckoolByVijay/PowerShell-Scripts/tree/main/CSV_Manipulation
* github : https://github.com/TechSckoolByVijay/PowerShell-Scripts/blob/main/CSV_Manipulation/CSV_manipulation.ps1


== Voir aussi ==
== Voir aussi ==
* &nbsp;
* &nbsp;
[[Catégorie:PowerShell]]

Dernière version du 2 novembre 2023 à 16:55

Script de nettoyage de contenu de fichier

# Traitement de texte sur fichier brut (enlever les lignes qui contiennent les mots ou expressions indiquées) ; le nouveau fichier est "fichier2.txt"
# l'expression "^[?]" indique une ligne commençant par un point d'interrogation.
# la barre verticale sépare les expressions recherchées ; les espaces sont pris en compte.
$fichier = get-content "c:\tmp\scores.txt" | where {$_ -notmatch "^[?]|putain|bite|caca| cul| chauve| mere"}
set-content fichier2.txt $fichier

Script de suppression de fichier

Suppression des fichiers anciens

<#
Description : suppression des fichiers dont la date de création est ancienne
Usage       : exécution du script via une tâche planifiée
Auteur      : PHP
Version     : 1.0
Révisions   :
	- 1.0 (05/05/2023) : création du script
#>

$FichierAnciennete = -30
$Dossier = "C:\log"
Get-ChildItem $Dossier -Recurse | Where CreationTime -lt (Get-Date).AddDays($FichierAnciennete) | Remove-Item -Force -Recurse

Exemple

# Auteur : Ph. Page
# Création : 01/12/2021
# Modification :
#
# Script de suppression de fichiers de façon récursive !
#

Clear-Host

$CheminListe = @(
    'C:\test\dossier1',
    'C:\test\qcm',
    'C:\test\Rufus'
    )

Clear-Host
Write-Host "Demande de confirmation de suppression des fichiers des dossiers suivants :"
Write-host $CheminListe -Separator "`n"

$Reponse = Read-Host "`nEtes-vous sûr de cette action ? (O/N)"
if ($reponse -eq "O") {
    Write-Host "`n==> Traitement lancé..."
    foreach ($Chemin in $CheminListe) {
        if (Test-Path $Chemin) {
            Get-ChildItem -file -recurse -Force -path $chemin | Remove-Item
            #Get-ChildItem -file -recurse -Force -path $chemin
        }
        else {
            Write-Host "`tLe dossier suivant n'existe pas ! $Chemin"
        }
    }
    Write-Host "==> Traitement terminé."
}
else {
    Write-Host "Traitement non lancé."
}

Résultat :

Complément

Liste des dix plus gros fichiers, tri décroissant :

  • Get-ChildItem -file *.vhdx -recurse | sort Length -descending | select -first 10 | Select-Object Name, @{Name="Mo";Expression={$_.Length / 1MB}}

Liste des dix plus gros fichiers, tri décroissant, avec mise en forme des valeurs numériques en Mo et 3 chiffres après la virgule :

  • Get-ChildItem -file *.* -recurse | sort Length -descending | select -first 10 | Select-Object -property Name, @{Label="Mo";Expression={"{0:N3}" -f ($_.Length / 1MB)}}

Script de liste (fichier, dossier...)

Liste de dossiers, nombre de fichier et taille

Ce script génère un tableau des dossiers, nombre de fichiers et taille totale, avec tri du plus grand au plus petit.

Clear-Host
$DossierSource = 'C:\Support'

# Ne liste que les dossiers de premier niveau
$DossierListe = Get-ChildItem -Directory -Path $DossierSource -Depth 0

$DossierListe |
ForEach-Object {
    $Dossier = $_.FullName
    $FichierNombre = (Get-ChildItem -Path $Dossier -Recurse -File).count
    $Taille = (Get-ChildItem -Path $Dossier -Recurse -File | Measure-Object -Property Length -Sum).Sum
    $Rapport = $Taille/($FichierNombre + 1)

    [pscustomobject]@{
        Répertoire     = $Dossier
        Nombre_fichier = $FichierNombre
        Taille_MB      = '{0:N2}' -f ($Taille/1MB)
        Taille_GB      = '{0:N2}' -f ($Taille/1GB)
        Rapport_MB     = '{0:N2}' -f ($Rapport/1MB)
    }
} | 
Sort-Object Rapport_MB -Descending | 
FT 
#| Export-CSV -Path C:\support\raccourcis-liste-20230403.csv -Delimiter ";"

Liste de fichiers en fonction de l'extension, de la taille

$DossierTravail = "C:\php\"

#$filtre = @(".jpg",".jpeg") # filtre pour les images au format jpg
$filtre = @(".mp4",".mov") # filtre pour les vidéos

$tailleMinimum = "2000000" # en octet (2000000 pour 2 Mo)
$ancienneteAnnee = "2023" # jusque l'année indiquée

Clear-Host

Set-Location $DossierTravail

Write-Output "Début du traitement..."
$FichierListe = Get-ChildItem -Recurse | Where-Object { ($_.Extension -in $filtre) -and ($_.Length -ge $tailleMinimum) -and ($_.CreationTime.Year -le $ancienneteAnnee) } | FT name, Length, LastWriteTime, Directory
Write-Output "Fin du traitement"

$FichierListe

Script de suppression de fichiers temporaires sur profil itinérant

$Compte = "martinp"
$DossierListe = @(
    "C:\Users\$Compte\AppData\Local\Microsoft\Edge\User Data\Default\Cache\Cache_Data\",
    "C:\Users\$Compte\AppData\LocalLow\Adobe\Acrobat\DC\ConnectorIcons\"
    "C:\Users\$Compte\AppData\Local\Microsoft\Windows\INetCache\Content.Outlook\",
    "C:\Users\$Compte\AppData\Local\Microsoft\Edge\User Data\Default\Service Worker\CacheStorage\"
)

foreach ($Dossier in $dossierliste) {
    Get-ChildItem -path $Dossier -exclude "index"
    $FichierNombre = (Get-ChildItem -Path $Dossier -Recurse -File -include "*.pdf").count
    $Taille = (Get-ChildItem -Path $Dossier -Recurse -File -include "*.pdf" | Measure-Object -Property Length -Sum).Sum
    $TotalTaille = $TotalTaille + $Taille
}
$TotalTaille_MB      = '{0:N2}' -f ($TotalTaille/1MB)
write-host 
write-host "=== Bilan ==="
write-host "Nombre de dossier racine :", $DossierListe
write-host "Nombre de dossier racine :", $DossierListe.Count
write-host "Nombre de fichiers :", $FichierNombre
write-host "Taille totale (Mo) :", $TotalTaille_MB

# exemples
# Get-ChildItem -Path "C:\" -Recurse -File -include "*.pdf"

Traitement de fichier CSV

Vidéo Youtube, TechSckool, CSV File Handling with PowerShell :

Voir aussi

  •