配置文件要能实现查找文件夹个数和文件路径,大小,名称  望高手回复哈

解决方案 »

  1.   


    '配置文件类本类提供INI文件的读写,修改,删除
    'Dim settingfile As New classIniFile'
    'settingfile.delinikey 删二级值
    'settingfile.delinidec 删除项
    'settingfile.getinikey 获取值
    'settingfile.inifilename  指定文件(不存在则创建)
    'settingfile.writeinifile 写入值Option ExplicitPrivate strINI As String'说明
    '在初始化文件指定小节内设置一个字串
    '返回值
    'Long,非零表示成功,零表示失败。会设置GetLastError
    '参数表
    '参数 类型及说明
    'lpApplicationName String,要在其中写入新字串的小节名称。这个字串不区分大小写
    'lpKeyName Any,要设置的项名或条目名。这个字串不区分大小写。用vbNullString可删除这个小节的所有设置项
    'lpString String,指定为这个项写入的字串值。用vbNullString表示删除这个项现有的字串
    'lpFileName String,初始化文件的名字。如果没有指定完整路径名,则windows会在windows目录查找文件。如果文件没有找到,则函数会创建它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
        
    '说明
    '为初始化文件中指定的条目取得字串
    '返回值
    'Long,复制到lpReturnedString缓冲区的字节数量,其中不包括那些NULL中止字符。如lpReturnedString缓冲区不够大,不能容下全部信息,就返回nSize-1(若lpApplicationName或lpKeyName为NULL,则返回nSize-2)
    '参数表
    '参数 类型及说明
    'lpApplicationName String,欲在其中查找条目的小节名称。这个字串不区分大小写。如设为vbNullString,就在lpReturnedString缓冲区内装载这个ini文件所有小节的列表
    'lpKeyName String,欲获取的项名或条目名。这个字串不区分大小写。如设为vbNullString,就在lpReturnedString缓冲区内装载指定小节所有项的列表
    'lpDefault String,指定的条目没有找到时返回的默认值。可设为空("")
    'lpReturnedString String,指定一个字串缓冲区,长度至少为nSize
    'nSize Long,指定装载到lpReturnedString缓冲区的最大字符数量
    'lpFileName String,初始化文件的名字。如没有指定一个完整路径名,windows就在Windows目录中查找文件
    '注解
    '如lpKeyName参数为vbNullString,那么lpReturnedString缓冲区会载入指定小节所有设置项的一个列表。每个项都用一个NULL字符分隔,最后一个项用两个NULL字符中止。也请参考GetPrivateProfileInt函数的注解
    '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 LongPrivate Function MakePath(ByVal strDrv As String, ByVal strDir As String) As String    Do While Right$(strDrv, 1) = "\"
              strDrv = Left$(strDrv, Len(strDrv) - 1)
        Loop
        
        Do While Left$(strDir, 1) = "\"
              strDir = Mid$(strDir, 2)
        Loop
        
        MakePath = strDrv & "\" & strDir
    End FunctionPrivate Sub CreateIni(strDrv As String, strDir As String)
        strINI = MakePath(strDrv, strDir)
    End SubPublic Sub WriteIniKey(strSection As String, strKey As String, strValue As String)
        WritePrivateProfileString strSection, strKey, strValue, strINI
    End SubPublic Function GetIniKey(strSection As String, strKey As String) As String
        Dim strTmp As String
        Dim lngRet As String
        Dim I As Integer
        Dim strTmp2 As String
        
        strTmp = String$(1024, Chr(32))
        lngRet = GetPrivateProfileString(strSection, strKey, "", strTmp, Len(strTmp), strINI)
        strTmp = Trim(strTmp)
        strTmp2 = ""
        For I = 1 To Len(strTmp)
            If Asc(Mid(strTmp, I, 1)) <> 0 Then
                strTmp2 = strTmp2 + Mid(strTmp, I, 1)
            End If
        Next I
        strTmp = strTmp2
        
        GetIniKey = strTmp
    End FunctionPublic Property Let INIFileName(ByVal New_IniPath As String)
        strINI = New_IniPath
    End PropertyPublic Property Get INIFileName() As String
        INIFileName = strINI
    End PropertyPublic Function DelIniKey(ByVal SectionName As String, ByVal KeyWord As String)
        Dim RetVal As Integer
        RetVal = WritePrivateProfileString(SectionName, KeyWord, 0&, strINI)
    End FunctionPublic Function DelIniSec(ByVal SectionName As String)
        Dim RetVal As Integer
        RetVal = WritePrivateProfileString(SectionName, 0&, "", strINI)
    End Function