Compartilhar via


LINQ e diretórios de arquivos (Visual Basic)

Muitas operações do sistema de arquivos são essencialmente consultas e, portanto, são ideais para a abordagem do LINQ.

Observe que as consultas nesta seção são não destrutivas. Elas não são usadas para alterar o conteúdo dos arquivos ou pastas originais. Isso segue a regra de que consultas não devem causar efeitos colaterais. Em geral, qualquer código (incluindo consultas que executam operadores criar / atualizar / excluir) que modifique dados de origem deve ser mantido separado do código que apenas consulta os dados.

Esta seção contém os seguintes tópicos:

Como consultar arquivos com um atributo ou nome especificado (Visual Basic)
Mostra como pesquisar arquivos, examinando uma ou mais propriedades de seu objeto FileInfo.

Como agrupar arquivos por extensão (LINQ) (Visual Basic)
Mostra como retornar grupos de objetos FileInfo com base em sua extensão de nome de arquivo.

Como consultar o número total de bytes em um conjunto de pastas (LINQ) (Visual Basic)
Mostra como retornar o número total de bytes em todos os arquivos de uma árvore de diretórios especificada.

Como comparar o conteúdo de duas pastas (LINQ) (Visual Basic)s
Mostra como retornar todos os arquivos que estão presentes em duas pastas especificadas e também todos os arquivos que estão presentes em uma pasta, mas não na outra.

Como consultar o maior arquivo ou arquivos em uma árvore de diretório (LINQ) (Visual Basic)
Mostra como retornar o maior ou o menor arquivo ou um número especificado de arquivos, em uma árvore de diretório.

Como consultar arquivos duplicados em uma árvore de diretório (LINQ) (Visual Basic)
Mostra como agrupar todos os nomes de arquivo que ocorrem em mais de um local em uma árvore de diretórios especificada. Também mostra como realizar comparações mais complexas com base em um comparador personalizado.

Como consultar o conteúdo de arquivos em uma pasta (LINQ) (Visual Basic)
Mostra como iterar pelas pastas em uma árvore, abrir cada arquivo e consultar o conteúdo do arquivo.

Comentários

Há certa complexidade envolvida na criação de uma fonte de dados que representa o conteúdo do sistema de arquivos com precisão e trata exceções de maneira elegante. Os exemplos nesta seção criam uma coleção de instantâneos de objetos FileInfo que representa todos os arquivos em uma pasta raiz especificada e todas as suas subpastas. O estado real de cada FileInfo pode ser alterado no tempo entre o momento em que você começa e termina a execução de uma consulta. Por exemplo, você pode criar uma lista de objetos FileInfo para usar como uma fonte de dados. Se você tentar acessar a propriedade Length em uma consulta, o objeto FileInfo tentará acessar o sistema de arquivos para atualizar o valor de Length. Se o arquivo não existir, você obterá uma FileNotFoundException em sua consulta, embora não esteja consultando diretamente o sistema de arquivos. Algumas consultas nesta seção usam um método separado que consome essas exceções específicas em determinados casos. Outra opção é manter a fonte de dados atualizada dinamicamente usando o FileSystemWatcher.

Confira também