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
Rubrik: Dateisystem · INI-Dateien   |   VB-Versionen: VB613.05.05
INI-Dateien und das MultiLine-Textproblem

Dieser Tipp verrät, wie sich auch mehrzeilige Texte mit Zeilenumbrüchen in einer INI-Datei speichern und wieder auslesen lassen.

Autor:   Dieter OtterBewertung:     [ Jetzt bewerten ]Views:  16.267 
www.tools4vb.deSystem:  Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

INI-Dateien sind aufgrund ihres einfachen Aufbaus und des einfachen Zugriffs immer noch sehr beliebt. Will man in einer INI-Datei jedoch einen mehrzeiligen Text mit Zeilenumbrüchen speichern, hat man ein kleines Problem: Beim Auslesen bekommt man immer nur die erste Textzeile zurückgeliefert, da die INI-Datei selbst zeilenorientiert aufgebaut ist und sich über die API-Zugriffsfunktionen somit immer nur eine einzige Zeile auslesen lässt.

Was aber spricht dagegen, die Zeilenumbrüche beim Speichern einfach durch "Platzhalter" zu ersetzen? Nichts Ok... dann tun wir das auch!
Beim Auslesen des INI-Eintrags braucht dann der Platzhalter einfach nur wieder zurück in einen Zeilenumbruch umgewandelt werden.

Fügen Sie hierzu nachfolgenden Code in ein Modul ein:

Option Explicit
 
' Benötigte API-Deklarationen für den INI-Zugriff
Public Declare Function GetPrivateProfileString Lib "kernel32" _
  Alias "GetPrivateProfileStringA" ( _
  ByVal lpApplicationName As String, _
  ByVal lpKeyName As Any, _
  ByVal lpDefault As String, _
  ByVal lpReturnedString As String, _
  ByVal nSize As Long, _
  ByVal lpFileName As String) As Long
 
Public Declare Function WritePrivateProfileString Lib "kernel32" _
  Alias "WritePrivateProfileStringA" ( _
  ByVal lpApplicationName As String, _
  ByVal lpKeyName As Any, _
  ByVal lpString As Any, _
  ByVal lpFileName As String) As Long
' Eintrag in INI-Datei speichern unter Berücksichtigung
' von Zeilenumbrüchen
Public Sub WriteIniString(ByVal sSection As String, _
  ByVal sKey As String, _
  ByVal sText As String, _
  ByVal sINIFile As String)
 
  Dim nResult As Long
 
  ' Zeilenumbrüche im Text ersetzen
  WritePrivateProfileString sSection, sKey, _
    Replace(sText, vbCrLf, "%cr"), sINIFile
End Sub
' INI-Eintrag lesen unter Berücksichtigung und
' Zeileumbruchszeichen zurückwandeln
Public Function ReadIniString(ByVal sSection As String, _
  ByVal sKey As String, _
  ByVal sDefault As String, _
  ByVal sINIFile As String)
 
  Dim nResult As Long
  Dim sBuffer As String
 
  ' max. Länge vorgeben: 1024
  sBuffer = Space$(1024)
 
  nResult = GetPrivateProfileString(sSection, sKey, _
    sDefault, sBuffer, Len(sBuffer), sINIFile)
 
  If nResult > 0 Then
    ' Zeilenumbruch-Platzhalter ersetzen
    ReadIniString = Replace(RTrim$(sBuffer), "%cr", vbCrLf)
  End If
End Function

Ab sofort verwenden Sie zum Speichern und Lesen von mehrzeiligen Texten die beiden Funktionen WriteIniString bzw. ReadIniString.
 

Dieser Tipp wurde bereits 16.267 mal aufgerufen.

Voriger Tipp   |   Zufälliger Tipp   |   Nächster Tipp

Über diesen Tipp im Forum diskutieren
Haben Sie Fragen oder Anregungen zu diesem Tipp, können Sie gerne mit anderen darüber in unserem Forum diskutieren.

Neue Diskussion eröffnen

nach obenzurück


Anzeige

Kauftipp Unser Dauerbrenner!Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv  Vol.6
(einschl. Beispielprojekt!)

Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
- nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten
- Symbol-Galerie mit mehr als 3.200 Icons im modernen Look
Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m.
 
   

Druckansicht Druckansicht 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