Vb ini 文件操作类

最近有用到,顺便记录下来。呵呵

 

ExpandedBlockStart.gif 代码
Private  Declare  Function  GetPrivateProfileInt Lib  " kernel32 "  Alias  " GetPrivateProfileIntA "  (ByVal lpApplicationName  As   String , ByVal lpKeyName  As   String , ByVal nDefault  As   Long , ByVal lpFileName  As   String As   Long
    
Private  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
      
Private  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

Private  IniFileName  As   String

Public  ErrorMsg  As   String

Private   Sub  Class_Initialize()
     IniFileName 
=  vbNullString
     ErrorMsg 
=  vbNullString
End Sub

Public   Sub  SpecifyIni(FilePathName)
     IniFileName 
=   Trim (FilePathName)
End Sub

Private   Function  NoIniFile()  As   Boolean
     NoIniFile 
=   True
     
If  IniFileName  =  vbNullString  Then
         ErrorMsg 
=   " 没有指定 INI 文件 "
         
Exit   Function
     
End   If
     ErrorMsg 
=  vbNullString
     NoIniFile 
=   False
End Function

 
Public   Function  WriteString(Section  As   String , key  As   String , Value  As   String As   Boolean
     WriteString 
=   False
     
If  NoIniFile()  Then
         
Exit   Function
     
End   If
     
If  WritePrivateProfileString(Section, key, Value, IniFileName)  =   0   Then
         ErrorMsg 
=   " 写入失败 "
         
Exit   Function
     
End   If
     WriteString 
=   True
End Function

Public   Function  ReadString(Section  As   String , key  As   String , Optional Size  As   Long As   String
     
Dim  ReturnStr  As   String
     
Dim  ReturnLng  As   Long
     
If  Size  =   0   Then  Size  =   50
     ReadString 
=  vbNullString
     
If  NoIniFile()  Then
         
Exit   Function
     
End   If
     ReturnStr 
=   Space (Size)
     ReturnLng 
=  GetPrivateProfileString(Section, key,  "" , ReturnStr, Size, IniFileName)
     ReadString 
=   Left (ReturnStr, ReturnLng)
End Function

Public   Function  ReadInt(Section  As   String , key  As   String As   Long
     
Dim  ReturnLng  As   Long
     ReadInt 
=   0
     ReturnLng 
=  GetPrivateProfileInt(Section, key,  0 , IniFileName)
     
If  ReturnLng  =   0   Then
         ReturnLng 
=  GetPrivateProfileInt(Section, key,  1 , IniFileName)
         
If  ReturnLng  =   1   Then
             ErrorMsg 
=   " 不能读取 "
             
Exit   Function
         
End   If
     
End   If
     ReadInt 
=  ReturnLng
End Function

 

 

 

转载于:https://www.cnblogs.com/lano/archive/2009/12/09/1620085.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值