Kako urejati csv in besedilne datoteke z VBA (Excelovi makri).


Datum objave:5. julij 2022.



INFOMARTION > Kako urejati csv in besedilne datoteke z VBA (Excelovi makri).

Pregled.

Opisati želim, kako urejati datoteke csv in besedilne datoteke z VBA (Excelovi makri). Članek je namenjen ljudem, ki želijo programirati naslednje naloge

  • Že obstoječi datoteki csv ali besedilni datoteki želim dodati vrstice. Besedilo želim dodati na sredino vrstice.
  • Želim izbrisati vrstice v že obstoječi datoteki csv ali besedilni datoteki.

Kazalo vsebine

  1. Metoda programiranja
  2. Opis kode.
  3. povzetek

1. Metoda programiranja

FileSystemObject nima možnosti dodajanja sredi vrstice ali brisanja določene vrstice, zato morate to programirati sami.

V nadaljevanju so navedeni referenčni primeri programiranja.

Ker je ustvarjen v funkciji Function, bi ga rad prenesel tako, kot je, s kopiranjem in lepljenjem, klici metod pa bi bili izvedeni iz Sub.

'Parameter Examples
'## filePath      C:\Users\user\Desktop\test\test.txt
'## mode          false:delete, true:write
'## targetRow     10
'## targetInput   If in write mode, any character
'## lineBreakType false:vbLf, true:vbCrLf

Function editFile(filePath As String, mode As Boolean, targetRow As Long, targetInput As String, lineBreakType As Boolean)
 
'File existence check
If Dir(filePath) = "" Then
  MsgBox "File does not exist!"
  Exit Function
End If
 
Dim tempText As String
Dim tempTextBefore As String
Dim tempTextNew As String
Dim tempTextAfter As String
Dim resultText As String
Dim i As Long
'File read
With CreateObject("ADODB.Stream")
  .Charset = "UTF-8"
  .Open
  .LoadFromFile filePath
  tempText = .ReadText
  .Close
End With
Dim tempTextBeforeRow As Long
tempTextBeforeRow = 0
For i = 1 To targetRow - 1
  If lineBreakType Then
    tempTextBeforeRow = InStr(tempTextBeforeRow + 1, tempText, vbCrLf)
  Else
    tempTextBeforeRow = InStr(tempTextBeforeRow + 1, tempText, vbLf)
  End If
Next i
If lineBreakType Then
  tempTextBeforeRow = tempTextBeforeRow + 1
End If
 
tempTextBefore = Left(tempText, tempTextBeforeRow)
'write
If mode Then
  tempTextAfter = Mid(tempText, tempTextBeforeRow + 1, Len(tempText))
  If lineBreakType Then
    tempTextNew = targetInput & vbCrLf
  Else
    tempTextNew = targetInput & vbLf
  End If
  resultText = tempTextBefore & tempTextNew & tempTextAfter
'delete
Else
  Dim tempTextAfterRow As Long
  tempTextAfterRow = 0
  For i = 1 To CInt(targetRow)
    If lineBreakType Then
      tempTextAfterRow = InStr(tempTextAfterRow + 1, tempText, vbCrLf)
    Else
      tempTextAfterRow = InStr(tempTextAfterRow + 1, tempText, vbLf)
    End If
  Next i
  If lineBreakType Then
    tempTextAfterRow = tempTextAfterRow + 1
  End If
  tempTextAfter = Mid(tempText, tempTextAfterRow + 1, Len(tempText))
  resultText = tempTextBefore & tempTextAfter
End If
 
With CreateObject("ADODB.Stream")
  .Charset = "UTF-8"
  If lineBreakType Then
    .LineSeparator = -1
  Else
    .LineSeparator = 10
  End If
  .Open
  .WriteText tempTextBefore & tempTextNew & tempTextAfter, 0
  .SaveToFile filePath, 2
  .Close
End With
End Function

Če ga želite uporabiti, podajte naslednje argumente.

  • filePath・・・To bo polna pot do datoteke. Primer.)C:\Users\user\Desktop\test\test.txt
  • mode・・・Pass true, false. Če je True, dodajte. Če je false, izbrišite vrstico.
  • targetRow・・・Določa število ciljnih vrstic. V primeru dodajanja je to število vrstic, ki jih je treba dodati, v primeru brisanja pa število vrstic, ki jih je treba izbrisati.
  • targetInput・・・Za naknadne skripte določite vrednost, ki jo je treba dodati. Ne uporablja se za brisanje in je lahko poljubna vrednost. Sprejemljive so tudi prazne črke.
  • lineBreakType・・・Nastavitev znakov nove vrstice. Če je True, vbCrLf. vbLf if False. Skratka, True za datoteke, ustvarjene v operacijskem sistemu Windows.

Kodiranje znakov je UTF-8, če ga želite spremeniti, neposredno spremenite kodo funkcije. Na dveh mestih je ".Charset = "UTF-8"".

Primer izvajanja dejanskega klica funkcije je prikazan spodaj.

Sub test()
 
'Primer dodajanja test123 v vrstico 5 v datoteki test.txt.(Datoteke, ustvarjene v sistemu Windows.)
editFile "C:\Users\user\Desktop\test\test.txt", True, 5, "test123", True
 
'Primer brisanja vrstice 5 v datoteki test.txt.(Datoteke, ustvarjene v sistemu Windows.)
editFile "C:\Users\user\Desktop\test\test.txt", False, 5, "", True
 
End Sub

Če želite pripeti kot csv, je argument vrednosti, ki jo želite pripeti, vrednost, ločena z vejico, in priložena bo vrednost, ločena z vejico. Primer.)"test1,test2,test3"

2. Opis kode.

To je konec navodil za uporabo sistema, ki mu sledi razlaga kode.

Podrobnosti so na voljo v kodi, vendar je okvirni potek postopka naslednji.

Za postscriptum.

  • ①Branje besedilnih datotek na poteh, posredovanih kot argumenti.
  • ②Število znakov do števila vrstic, posredovanih v argumentu, je določeno iz števila novih vrstic. Na primer, v vrstici 5 so pred vrstico 5 štirje prelomi vrstice, zato poiščite položaj, kjer se nahaja četrti prelom vrstice.
  • ③Pridobite informacije do vrstice 4.
  • ④(2) Na enak način kot v točki (2) pridobite informacije od vrstice 5 naprej.
  • ⑤Informacije iz točke (3), informacije, ki se dodajo kot argument, in informacije iz točke (4) se združijo.
  • ⑥Ustvarite datoteko na podlagi informacij iz (5) in jo prepišite.

V primeru izbrisa

  • ①Branje besedilnih datotek na poteh, posredovanih kot argumenti.
  • ②Število znakov do števila vrstic, posredovanih v argumentu, je določeno iz števila novih vrstic. Na primer, v vrstici 5 so pred vrstico 5 štirje prelomi vrstice, zato poiščite položaj, kjer se nahaja četrti prelom vrstice.
  • ③Pridobite informacije do vrstice 4.
  • ④(ii) Na enak način kot v točki (ii) pridobite informacije od vrstice 6 naprej.
  • ⑤Informacije iz točk (iii) in (iv) se združijo. (Ustvari niz brez pete vrstice.)
  • ⑥Ustvarite datoteko na podlagi informacij iz (5) in jo prepišite.

V primeru dodajanja in brisanja sta oba postopka enaka, vendar se namesto urejanja datoteke naredi tako, da se iz prvotne datoteke odstranijo le potrebni podatki, ustvari in shrani pa se nova datoteka.

3. povzetek

Če imate težave pri urejanju datotek csv/besedilnih datotek s programom VBA (Excelovi makri), si oglejte to poglavje.

Hvala, ker ste gledali do konca.




■INFORMATION

Kliknite tukaj za prehod na zgornjo stran INFORMACIJE.


■PROFILE

Kliknite tukaj za profil.


■Kontaktni podatki.

Za poizvedbe o članku nam pišite tukaj.