GetFullPathName

王朝百科·作者佚名  2010-03-06  
宽屏版  字体: |||超大  

VB声明Declare Function GetFullPathName& Lib "kernel32" Alias "GetFullPathNameA" (ByVal lpFileName As String, ByVal nBufferLength As Long, ByVal lpBuffer As String, lpFilePart As Long)

说明

获取指定文件的完整路径名

返回值

Long,装载到lpBuffer中的字符数量(排除空中止字符)。如缓冲区的长度不足以容下完整的路径,则返回值就是要求的缓冲区大小。零表示失败。会设置GetLastError

参数表

参数 类型及说明

lpFileName String,指定文件名(长文件名或8.3格式的DOS文件名)

nBufferLength Long,lpBuffer字串的长度

lpBuffer String,指定一个预先定义好的字串,用于装载目标文件的驱动器及路径名称。如存在长文件名,那么这个参数保存的就肯定是长文件名

lpFilePart Long,指定一个长整数变量,用于装载文件名起始的地方。参考注解

注解

lpFilePart参数在vb里很难使用。它的问题在于:尽管windows在这个Long值中装载lpBuffer字串中的地址,用它表示路径信息文件名部分的起始处。但非常不幸,由vb创建的、传递给api的ANSI字串缓冲区也会使用这个地址。等这个函数返回的时候,vb已将返回的(lpBuffer)字串复制回它的内部Unicode字串缓冲区,所以lpFilePart地址已没有任何意义。因此,我们面临两种选择。首先,可以简单的不使用lpFilePart信息(忽略windows装载在参数中的值)。其次,可以将lpBuffer参数变成一个字节数组(lpFilePart As Byte——将数组的第一个元素作为参数传递)

其他

在vb的api文本查看器中复制的声明为:Declare Function GetFullPathName Lib "kernel32" Alias "GetFullPathNameA" (ByVal lpFileName As String, ByVal nBufferLength As Long, ByVal lpBuffer As String, ByVal lpFilePart As String) As Long

VC声明DWORD GetFullPathName(

LPCTSTR lpFileName, // file name

DWORD nBufferLength, // size of path buffer,建议取值为:MAX_PATH

LPTSTR lpBuffer, // path buffer

LPTSTR *lpFilePart // address of file name in path

);

功能说明

从一指定文件得到文件的路径

参数说明

LPCTSTR lpFileName, 指定文件的名字

DWORD nBufferLength,缓存区的大小

LPTSTR lpBuffer, 用于存放路径的缓存区

LPTSTR *lpFilePart 文件名的起始地址

返回值

如果调用成功 返回实际路径的长度

如果缓冲区太小,不能装下文件完整路径的话 返回值就是缓冲区的值 所以我们一般都将缓存区大小设置得足够大

调用失败 返回0 用GetLastError获得错误信息

 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
© 2005- 王朝百科 版权所有