vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
NEU! sevCoolbar 3.0 - Professionelle Toolbars im modernen Design!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Re: CSV- Datei ändern und im Anschluss verschieben 
Autor: HenryV
Datum: 25.10.17 16:56

Hier einmal eine Lösung mit dem FileSystemWatcher: (Ich hatte noch ein bisschen Zeit übrig)

Eine Form mit btnStart (Button), btnStop (Button), tbImport (TextBox), tbExport (TextBox), llbImport (LinkLabel) und llbExport (LinkLabel)
dazu zwei Einstellungen ImportPfad (String) und ExportPfad (String). Anleitung
Imports System.IO
Imports System.Text
 
Public Class Form1
    Private watcher As New FileSystemWatcher()
 
    Public Sub New()
        ' Dieser Aufruf ist für den Designer erforderlich.
        InitializeComponent()
 
        ' Watch for changes in LastAccess and LastWrite times, and the renaming 
        ' of files or directories. 
        watcher.NotifyFilter = (NotifyFilters.LastAccess Or _
          NotifyFilters.LastWrite Or NotifyFilters.FileName Or _
          NotifyFilters.DirectoryName)
        ' Only watch csv files.
        watcher.Filter = "*.csv"
 
        ' Add event handlers.
        AddHandler watcher.Changed, AddressOf OnChanged
        AddHandler watcher.Created, AddressOf OnChanged
 
        btnStop.Enabled = False
        tbExport.ReadOnly = True
        tbImport.ReadOnly = True
 
    End Sub
 
    Private Sub btnStart_Click(sender As Object, e As EventArgs) Handles _
      btnStart.Click
        If Directory.Exists(tbImport.Text) And Directory.Exists(tbExport.Text) _
        Then
            watcher.Path = tbImport.Text
            ' Begin watching.
            watcher.EnableRaisingEvents = True
            btnStart.Enabled = False
            btnStop.Enabled = True
        Else
            MessageBox.Show("Bitte beide Pfade angeben", Me.Text, _
              MessageBoxButtons.OK, MessageBoxIcon.Error)
        End If
    End Sub
 
    Private Sub btnStop_Click(sender As Object, e As EventArgs) Handles _
      btnStop.Click
        ' Stop watching.
        watcher.EnableRaisingEvents = False
        btnStart.Enabled = True
        btnStop.Enabled = False
    End Sub
 
    Private Sub FixCSV(ByVal InputFilePath As String, ExportFilePath As String)
        Using tfp As Microsoft.VisualBasic.FileIO.TextFieldParser = New _
          Microsoft.VisualBasic.FileIO.TextFieldParser(InputFilePath, _
          Encoding.Default)
            tfp.SetDelimiters(";")
            Using sw As StreamWriter = New StreamWriter(ExportFilePath, False, _
              Encoding.Default)
                Dim i As Integer = 0
                Dim Zeile As String = ""
                Do
                    Dim fields As String() = tfp.ReadFields
                    If fields Is Nothing Then Exit Do
                    For x As Integer = 0 To fields.Length - 1
                        If x = 30 Then
                            Zeile = String.Join(";"c, {Zeile, fields(x).Split( _
                              ";"c)(i)})
                        Else
                            Zeile = String.Join(";"c, {Zeile, fields(x)})
                        End If
                    Next
                    sw.WriteLine(Zeile.Substring(1))
                    Zeile = ""
                    i += 1
                Loop
            End Using
        End Using
    End Sub
 
    Private Sub OnChanged(source As Object, e As FileSystemEventArgs)
        ' Specify what is done when a file is changed or created.
        Dim exportFilePath As String = IO.Path.Combine(tbExport.Text, _
          IO.Path.GetFileName(e.FullPath))
        FixCSV(e.FullPath, exportFilePath)
    End Sub
 
    Private Sub llbImport_LinkClicked(sender As Object, e As _
      LinkLabelLinkClickedEventArgs) Handles llbImport.LinkClicked
        Dim dialog As New FolderBrowserDialog()
        If tbImport.Text <> "" Then dialog.SelectedPath = tbImport.Text
        If DialogResult.OK = dialog.ShowDialog() Then
            tbImport.Text = dialog.SelectedPath
            My.Settings.ImportPfad = tbImport.Text
            My.Settings.Save()
        End If
    End Sub
 
    Private Sub llbExport_LinkClicked(sender As Object, e As _
      LinkLabelLinkClickedEventArgs) Handles llbExport.LinkClicked
        Dim dialog As New FolderBrowserDialog()
        If tbExport.Text <> "" Then dialog.SelectedPath = tbExport.Text
        If DialogResult.OK = dialog.ShowDialog() Then
            tbExport.Text = dialog.SelectedPath
            My.Settings.ExportPfad = tbExport.Text
            My.Settings.Save()
        End If
    End Sub
 
    Private Sub Form1_Load(sender As Object, e As EventArgs) Handles Me.Load
        tbExport.Text = My.Settings.ExportPfad
        tbImport.Text = My.Settings.ImportPfad
    End Sub
End Class
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
CSV- Datei ändern und im Anschluss verschieben1.948p2416.10.17 15:59
Re: CSV- Datei ändern und im Anschluss verschieben964Manfred X16.10.17 16:31
Re: CSV- Datei ändern und im Anschluss verschieben942p2425.10.17 08:20
Re: CSV- Datei ändern und im Anschluss verschieben879HenryV25.10.17 11:37
Re: CSV- Datei ändern und im Anschluss verschieben855p2425.10.17 13:22
Re: CSV- Datei ändern und im Anschluss verschieben984HenryV25.10.17 14:00
Re: CSV- Datei ändern und im Anschluss verschieben881p2425.10.17 14:52
Re: CSV- Datei ändern und im Anschluss verschieben898HenryV25.10.17 16:56
Re: CSV- Datei ändern und im Anschluss verschieben875p2426.10.17 08:35
Re: CSV- Datei ändern und im Anschluss verschieben868HenryV26.10.17 09:37
Re: CSV- Datei ändern und im Anschluss verschieben869p2426.10.17 10:05
Re: CSV- Datei ändern und im Anschluss verschieben939HenryV26.10.17 15:15
Re: CSV- Datei ändern und im Anschluss verschieben952p2427.10.17 07:36
Re: CSV- Datei ändern und im Anschluss verschieben814HenryV27.10.17 08:40
Re: CSV- Datei ändern und im Anschluss verschieben866p2427.10.17 09:54
Re: CSV- Datei ändern und im Anschluss verschieben848effeff27.10.17 20:45
Re: CSV- Datei ändern und im Anschluss verschieben842p2428.10.17 22:16
Re: CSV- Datei ändern und im Anschluss verschieben948HenryV27.10.17 12:14

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel