[.net2] compression/décompression gzip de fichier grâce à io.compression

Soyez le premier à donner votre avis sur cette source.

Vue 11 876 fois - Téléchargée 703 fois


Description

Un tout petit sample de la classe incroyablement pratique Io.Compression, permettant de compresser et de décompresser des fichiers à l'aide d'un algo puissant, et ce très rapidement. (aussi bien coté code que coté éxecution).
Merci le framework 2 !

Source / Exemple :


Imports System.IO
Imports System.IO.Compression

Public Class HbGzip

    Public Shared Function Compress(ByVal cheminSource As String, ByVal cheminCible As String) As String
        Try
            Dim hbread As New BinaryReader(File.OpenRead(cheminSource))
            Dim F_array(hbread.BaseStream.Length) As Byte
            hbread.BaseStream.Seek(0, SeekOrigin.Begin)
            hbread.BaseStream.Read(F_array, 0, F_array.Length)
            hbread.BaseStream.Flush()
            hbread.Close()
            Dim tmpstream As FileStream = New FileStream(cheminCible, FileMode.OpenOrCreate)
            Dim gzipper As GZipStream = New GZipStream(tmpstream, CompressionMode.Compress)
            gzipper.Write(F_array, 0, F_array.Length)
            gzipper.Flush()
            gzipper.Close()
            Return "compression effectuée avec succés"
        Catch ex As Exception
            Return ex.ToString
        End Try
    End Function

    Public Shared Function Decompress(ByVal cheminSource As String, ByVal cheminCible As String) As String
        Try
            Dim bufferLen As Integer = 1024
            Dim hbread As New BinaryReader(File.OpenRead(cheminSource))
            Dim gzipper As GZipStream = New GZipStream(hbread.BaseStream, CompressionMode.Decompress)
            Dim hbwrite As New BinaryWriter(File.OpenWrite(cheminCible))
            Dim F_array(bufferLen) As Byte
            Dim readlen As Integer
            Dim flag As Boolean = True
            Do
                readlen = gzipper.Read(F_array, 0, F_array.Length)
                If readlen > 0 Then
                    flag = True
                    If readlen = (bufferLen + 1) Then hbwrite.Write(F_array, 0, readlen) Else hbwrite.Write(F_array, 0, readlen - 1)
                Else
                    flag = False
                End If
            Loop While (flag)
            hbwrite.Close()
            gzipper.Close()
            Return "decompression effectuée avec succés"
        Catch ex As Exception
            Return ex.ToString
        End Try
    End Function
End Class

Codes Sources

A voir également

Ajouter un commentaire

Commentaires

Messages postés
56
Date d'inscription
mercredi 5 mai 2004
Statut
Membre
Dernière intervention
22 septembre 2009

Merci pour ce code !
Utilisateur anonyme
Perso, le résultat est bizarre !
1. Je choisi un fichier (Image.jpg)
2. Je donne un nom à mon fichier zip (test).

Je regarde (test.zip) avec Winrar et là, le fichier archivé à le même nom que l'archive (test) et pas d'extension.

Pour décompressé :
1. Je reprends mon fichier Zip.
2. Chose que je ne comprends pas, il me demande un autre nom ?!? Je lui tape (truc).

Le fichier décompressé, porte le second nom que j'ai donné (truc sans extention)
Résultat le fichier est correcte lorsque je lui remet l'extention (.jpg)
Quel étrangeté !
Pourquoi, après avoir demandé le nom de l'archive, ton script demande un nom de fichier pour la décompresser ? T'as déjà vu Winzip ou Winrar demander cela ? Un emplacement, Ok mais pas un nom de fichier...
Messages postés
34
Date d'inscription
lundi 10 juin 2002
Statut
Membre
Dernière intervention
20 octobre 2009

Mumuxe, un fichier compressé a toujours une entête qui fait X bytes avec en plus, la liste des fichiers compressés dans l'archive, leur taille, et d'autres informations (je ne sais pas ce qui est stocké exactement).
Ce qui fait que tu as X bytes d'entête suivis de tous les fichiers compressés.
Ce n'est pas un problème, c'est tout à fait normal.
Messages postés
2
Date d'inscription
lundi 14 septembre 2009
Statut
Membre
Dernière intervention
26 septembre 2009

Un bon code, très clair et bien rédigé. Pourtant, j'ai un petit problème. Lorsque je compresse un ficher, il en ressort ... plus GROS !!! Par exemple, pour un ficher texte de 24 octès à l'entrée, il y ressort avec 148 octès. Si quelqu'un pourrais m'expliquer et surtout apporter une solution au problème, ça serait gentil.
Messages postés
939
Date d'inscription
vendredi 25 octobre 2002
Statut
Membre
Dernière intervention
27 janvier 2009
1
j'adore les contributions sans suite... ^^
Afficher les 8 commentaires

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.