Thema Datum  Von Nutzer Rating
Antwort
21.11.2018 12:49:46 Gast51661
NotSolved
Blau CSV als UTF-8 importieren und in Tabelle schreiben
21.11.2018 14:46:40 Tina
NotSolved
21.11.2018 17:52:51 Gast26628
NotSolved
21.11.2018 18:48:08 Flotter Feger
NotSolved
22.11.2018 09:46:17 Franzi
NotSolved
22.11.2018 21:29:33 Flotter Feger
NotSolved

Ansicht des Beitrags:
Von:
Tina
Datum:
21.11.2018 14:46:40
Views:
836
Rating: Antwort:
  Ja
Thema:
CSV als UTF-8 importieren und in Tabelle schreiben

Ich habe mittlerweile den Code etwas angepasst, aber es ist sicher auch viel Schrott dabei, da ich nur mit dem Makro-Recorder aufgezeichnet und kopiert habe.

Leider habe ich das importieren mit UTF-8 nicht umsetzen können. Hat da jemand noch ideen wie der Code verändert werden muss, damit das auch sauber importiert wird? Habe vorallem Probleme mit Umlauten oder Sonderzeichen wie °C

 

Hier mein Code für die beiden Buttons:

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
Sub Neuer_Import_CSV()
   
 
  Dim strFileName As String, arrDaten, arrTmp, lngR As Long, lngLast As Long
  Const cstrDelim As String = ";" 'Trennzeichen
   
  With Application.FileDialog(msoFileDialogFilePicker)
    .AllowMultiSelect = False
    .Title = "Datei wählen"
    .InitialFileName = "\*.csv"  'Pfad anpassen
    If .Show = -1 Then
      strFileName = .SelectedItems(1)
    End If
  End With
   
  Rows("6:99999").Select
  Selection.Delete Shift:=xlUp
  Rows("5:5").Select
  Selection.ClearContents
   
  If strFileName <> "" Then
    Application.ScreenUpdating = False
    Open strFileName For Input As #1
    arrDaten = Split(Input(LOF(1), 1), vbCrLf)
    Close #1
    For lngR = 1 To UBound(arrDaten)
      arrTmp = Split(arrDaten(lngR), cstrDelim)
      If UBound(arrTmp) > -1 Then
        With ActiveSheet
          lngLast = .Cells(Rows.Count, 1).End(xlUp).Row + 1
          lngLast = Application.Max(lngLast, 5)
          .Cells(lngLast, 1).Resize(, UBound(arrTmp) + 1) _
            = Application.Transpose(Application.Transpose(arrTmp))
        End With
      End If
    Next lngR
  End If
  Rows("5:5").Select
  Selection.Delete Shift:=xlUp
  Range("K65").Select
  Sheets("Auswertung").PivotTables("Pivot_Auswertung").PivotCache.Refresh
   
End Sub
 
*******************************************************************************************
 
Sub CSV_Daten_am_Ende_hinzufügen()
 
 
  Dim strFileName As String, arrDaten, arrTmp, lngR As Long, lngLast As Long
  Const cstrDelim As String = ";" 'Trennzeichen
   
  With Application.FileDialog(msoFileDialogFilePicker)
    .AllowMultiSelect = False
    .Title = "Datei wählen"
    .InitialFileName = "\*.csv"  'Pfad anpassen
    If .Show = -1 Then
      strFileName = .SelectedItems(1)
    End If
  End With
     
  If strFileName <> "" Then
    Application.ScreenUpdating = False
    Open strFileName For Input As #1
    arrDaten = Split(Input(LOF(1), 1), vbCrLf)
    Close #1
    For lngR = 1 To UBound(arrDaten)
      arrTmp = Split(arrDaten(lngR), cstrDelim)
      If UBound(arrTmp) > -1 Then
        With ActiveSheet
          lngLast = .Cells(Rows.Count, 1).End(xlUp).Row + 1
          lngLast = Application.Max(lngLast, 5)
          .Cells(lngLast, 1).Resize(, UBound(arrTmp) + 1) _
            = Application.Transpose(Application.Transpose(arrTmp))
        End With
      End If
    Next lngR
  End If
  Rows("5:5").Select
  Selection.Delete Shift:=xlUp
  Range("K65").Select
  Sheets("Auswertung").PivotTables("Pivot_Auswertung").PivotCache.Refresh
   
End Sub

 


Ihre Antwort
  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen
Thema: Name: Email:



  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen

Thema Datum  Von Nutzer Rating
Antwort
21.11.2018 12:49:46 Gast51661
NotSolved
Blau CSV als UTF-8 importieren und in Tabelle schreiben
21.11.2018 14:46:40 Tina
NotSolved
21.11.2018 17:52:51 Gast26628
NotSolved
21.11.2018 18:48:08 Flotter Feger
NotSolved
22.11.2018 09:46:17 Franzi
NotSolved
22.11.2018 21:29:33 Flotter Feger
NotSolved