如何获取从短文件名的长文件名

注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。

154822
本文已归档。它按“原样”提供,并且不再更新。
概要
Dir() 函数可用于返回一个长文件名,但它不包含路径信息。通过解析成其构成目录的给定短的路径/文件名,您可以使用 Dir() 函数生成一个长路径/文件名。本文演示了如何完成这一行为。
更多信息
下面的代码示例包含一个函数,该函数会将短文件名转换其等价的长文件名,并还包括该函数的使用的简单演示。

分步示例

  1. 启动 Visual Basic。默认情况下创建 Form1。
  2. 将放置命令按钮拖到 Form1 上。
  3. 从插入菜单选择若要添加到项目的单个代码模块的模块。
  4. 将下面的代码添加到模块 1:
       Public Function GetLongFilename _     (ByVal sShortName As String) _     As String     Dim sLongName As String     Dim sTemp As String     Dim iSlashPos As Integer     'Add \ to short name to prevent Instr from failing     sShortName = sShortName & "\"     'Start from 4 to ignore the "[Drive Letter]:\" characters     iSlashPos = InStr(4, sShortName, "\")     'Pull out each string between \ character for conversion     While iSlashPos       sTemp = Dir(Left$(sShortName, iSlashPos - 1), _         vbNormal + vbHidden +    vbSystem + vbDirectory)       If sTemp = "" Then         'Error 52 - Bad File Name or Number         GetLongFilename = ""         Exit Function       End If       sLongName = sLongName & "\" & sTemp       iSlashPos = InStr(iSlashPos + 1, sShortName, "\")     Wend     'Prefix with the drive letter     GetLongFilename = Left$(sShortName, 2) & sLongName   End Function					
  5. 向 Command1_Click 事件中添加以下:
       Private Sub Command1_Click()     'Assumes C:\Program Files\Common Files is a valid path     Print GetLongFilename("C:\PROGRA~1\COMMON~1")   End Sub					
  6. 从运行菜单中选择启动或按 F5 键启动。
  7. 单击命令按钮。
有效您提供的路径是否将窗体上打印长的等效项。它是否无效任何内容将打印,请在这种情况下您需要提供一个有效的短文件名中 Command1_Click 事件代码。
kbVBp400 vkbVBp500bug kbVBp600bug kbVBp kbdsd kbDSupport KBWIN32SDK KBAPI

警告: 本文已自动翻译

属性

文章 ID:154822 - 上次审阅时间:02/21/2014 23:11:39 - 修订版本: 4.1

  • Microsoft Visual Basic 5.0 学习版
  • Microsoft Visual Basic 6.0 学习版
  • Microsoft Visual Basic 5.0 专业版
  • Microsoft Visual Basic 6.0 专业版
  • Microsoft Visual Basic 5.0 企业版
  • Microsoft Visual Basic Enterprise Edition for Windows 6.0
  • Microsoft Visual Basic 4.0 标准版
  • Microsoft Visual Basic 4.0 专业版
  • Microsoft Visual Basic 4.0 32-Bit Enterprise Edition
  • kbnosurvey kbarchive kbmt kbhowto KB154822 KbMtzh
反馈