Partilhar via


Como: Criar uma listagem de diretório

O exemplo de código a seguir mostra como utilizar as classes de E/S para criar uma listagem de todos os arquivos com a extensão ".exe" em um diretório.

Exemplo

Imports System
Imports System.IO

Public Class DirectoryLister
    Public Shared Sub Main(args() As String)
        Dim path As String = Environment.CurrentDirectory
        If args.Length > 0 Then
            If Directory.Exists(args(0)) Then
                path = args(0)
            Else
                Console.WriteLine("{0} not found; using current directory:",
                    args(0))
            End If
        End If
        Dim dir As New DirectoryInfo(path)
        For Each f As FileInfo In dir.GetFiles("*.exe")
            Dim name As String = f.Name
            Dim size As Long = f.Length
            Dim creationTime As DateTime = f.CreationTime
            Console.WriteLine("{0,-12:N0} {1,-20:g} {2}", size,
                creationTime, name)
        Next f
    End Sub
End Class
using System;
using System.IO;

public class DirectoryLister
{
    public static void Main(String[] args)
    {
        string path = Environment.CurrentDirectory;
        if (args.Length > 0)
        {
            if (Directory.Exists(args[0]))
            {
                path = args[0];
            }
            else
            {
                Console.WriteLine("{0} not found; using current directory:",
                    args[0]);
            }
        }
        DirectoryInfo dir = new DirectoryInfo(path);
        foreach (FileInfo f in dir.GetFiles("*.exe"))
        {
            string name = f.Name;
            long size = f.Length;
            DateTime creationTime = f.CreationTime;
            Console.WriteLine("{0,-12:N0} {1,-20:g} {2}", size,
                creationTime, name);
        }
    }
}
using namespace System;
using namespace System::IO;

public ref class DirectoryLister
{
public:
    static void Main(array<String^>^ args)
    {
        String^ path = Environment::CurrentDirectory;
        if (args->Length > 0)
        {
            if (Directory::Exists(args[0]))
            {
                path = args[0];
            }
            else
            {
                Console::WriteLine("{0} not found; using current directory:",
                    args[0]);
            }
        }
        DirectoryInfo^ dir = gcnew DirectoryInfo(path);
        for each (FileInfo^ f in dir->GetFiles("*.exe"))
        {
            String^ name = f->Name;
            long size = f->Length;
            DateTime^ creationTime = f->CreationTime;
            Console::WriteLine("{0,-12:N0} {1,-20:g} {2}", size,
                creationTime, name);
        }
    }
};

int main()
{
    DirectoryLister::Main(Environment::GetCommandLineArgs());
}

Programação robusta

Nesse exemplo, DirectoryInfo é o diretório atual, indicado por (". "), e o código lista todos os arquivos no diretório atual com uma extensão .exe, juntamente com seus tamanhos de arquivo, hora de criação e nome. Supondo que existam arquivos .exe no subdiretório \Bin de C:\MyDir, a saída desse código pode ter esta aparência:

953          7/20/2000 10:42 AM   C:\MyDir\Bin\paramatt.exe
664          7/27/2000 3:11 PM    C:\MyDir\Bin\tst.exe
403          8/8/2000 10:25 AM    C:\MyDir\Bin\dirlist.exe

Se você quiser uma lista de arquivos em outro diretório, como o diretório raiz C:\, passar o argumento "C:\" para o executável gerado por compilar esse código, por exemplo: "testApplication.exe C:\".

Observação

Os usuários de Visual Basic podem optar por usar os métodos e propriedades fornecidas pelo FileSystem classe para arquivo de e/S.

Consulte também

Tarefas

Como: Ler e gravar em um arquivo de dados recém-criado

Como: Abrir e anexar um arquivo de Log

Como: Ler texto de um arquivo.

Como: Gravar texto em um arquivo

Como: Caracteres de leitura de uma seqüência

Como: Gravar uma seqüência de caracteres

Referência

DirectoryInfo

CreationTime

FullName

FileInfo.Length

DirectoryInfo.GetFiles

Conceitos

Arquivo básico de E/S