|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Registered User
Iscritto dal: Mar 2011
Messaggi: 72
|
[VB] Backup dei file con ProgressBar
Salve a tutti!
Devo aggiungere ad un mio programma scritto in Visual Basic una funzione che effettui la copia di backup dei dati dell'utente dalla partizione dell'OS ad un'altra. Ho trovato sul Web del codice già pronto che però funziona parzialmente: Codice:
Private Sub CopyFile(ByVal sourceDir As String, ByVal targetDir As String)
Dim files() As String = IO.Directory.GetFiles(sourceDir, "*.*", IO.SearchOption.AllDirectories)
With pbr_backup
.Minimum = 0
.Value = .Minimum
.Maximum = files.Count
End With
Dim newDir As String
Dim FI As IO.FileInfo
For Each f As String In files
FI = New IO.FileInfo(f)
newDir = targetDir & "\" & FI.DirectoryName.Substring(sourceDir.Length) & "\"
If Not IO.Directory.Exists(newDir) Then IO.Directory.CreateDirectory(newDir)
IO.File.Copy(f, newDir & FI.Name, True)
pbr_backup.Value += 1
Next
MessageBox.Show("Copia completata.")
End Sub
Private Sub frm_recovery_os_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
Timer1.Enabled = True
End Sub
Private Sub Timer1_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Timer1.Tick
CopyFile("C:\UserFile", "E:\Backup")
End Sub
Qualcuno può aiutarmi a capire cosa c'è di sbagliato? Grazie in anticipo |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Jul 2008
Città: Roma
Messaggi: 542
|
Intanto non capisco perché usi un Timer ... non ha senso.
Per il tuo problema comunque, la riga pbr_backup.Value += 1 incrementa il valore per l'avanzamento della barra ... quindi non si capisce cosa non vada ... |
|
|
|
|
|
#3 |
|
Registered User
Iscritto dal: Mar 2011
Messaggi: 72
|
Grazie della risposta!!
Ho dovuto aggiungere il Timer perchè senza di esso la copia dei file viene avviata prima del caricamento del form con la barra di progresso, che non viene mostrato fino al termine della copia. Non conosco altro modo per aggirare il problema se non utilizzare il timer per ritardare la copia quanto basta per mostrare il form. Ad ogni modo, per la barra di progresso ho come l'impressione che il problema riguardi il ciclo "for". Invece di ripetere il codice all'interno del ciclo, pare che invece vengano eseguite anche tutte le altre istruzioni che lo precedono, ovvero: Codice:
With pbr_backup
.Minimum = 0
.Value = .Minimum
.Maximum = files.Count
End With
Dim newDir As String
Dim FI As IO.FileInfo
Ho provato a risolvere aggiungendo un ciclo While, ma niente da fare: Codice:
Private Sub CopyFile(ByVal sourceDir As String, ByVal targetDir As String)
Dim files() As String = IO.Directory.GetFiles(sourceDir, "*.*", IO.SearchOption.AllDirectories)
With pbr_backup
.Minimum = 0
.Value = .Minimum
.Maximum = files.Count
End With
Dim FilesTransferred As Integer = =
Dim newDir As String
Dim FI As IO.FileInfo
For Each f As String In files
FI = New IO.FileInfo(f)
newDir = targetDir & "\" & FI.DirectoryName.Substring(sourceDir.Length) & "\"
While FilesTransferred =< files.Count
If Not IO.Directory.Exists(newDir) Then IO.Directory.CreateDirectory(newDir)
IO.File.Copy(f, newDir & FI.Name, True)
pbr_backup.Value += 1
Next
MessageBox.Show("Copia completata.")
FilesTransferred +=1
End While
End Sub
|
|
|
|
|
|
#4 |
|
Registered User
Iscritto dal: Mar 2011
Messaggi: 72
|
Ok ho scoperto che alla fine era il Timer a fare casini, tolto quello la barra funziona correttamente. Il problema adesso è che senza il Timer la copia dei file parte PRIMA che il form sia caricato, quindi mi blocca tutto.
Come faccio a far partire automaticamente il processo di copia subito dopo che il form si è aperto? |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 06:53.



















