# ListFiles

## `ListFiles` (FB)

FUNCTION\_BLOCK ListFiles EXTENDS CBML.ETrig

### ListFiles

Der `ListFiles` Function-Block ermöglicht das Auflisten von Dateien in einem Verzeichnis. Dieser Function-Block bietet Konfigurationsoptionen für das Verzeichnis, Sortierkriterien und einen Filter für Dateinamen.

### Darstellung

<figure><img src="https://879424349-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FQR4vCFzt6ixgsqlR3pdR%2Fuploads%2FF1lynplpVWo49L95Qpwf%2FListFiles.png?alt=media&#x26;token=ae326f0f-7814-45e1-a585-793e9d54d854" alt=""><figcaption></figcaption></figure>

## Verwendung

Der Block wird verwendet, um Dateien in einem spezifizierten Verzeichnis zu lesen, zu filtern und Informationen zu den gefundenen Dateien und Verzeichnissen zurückzugeben.

## Eingänge

* **sDirectoryName:** STRING(254) Der Pfad des Verzeichnisses, das durchsucht werden soll. Standardmäßig ist dies ‘./’.
* **eSortBy:** SORT\_BY Das Kriterium, nach dem die Dateien sortiert werden sollen. Standardmäßig ist dies nach dem letzten Änderungsdatum.
* **sContains:** STRING Ein Filter, der angibt, welche Zeichenfolge die Dateinamen enthalten müssen. Standardmäßig ist dies ‘.csv’.
* **itfFileList:** COL.ISortedList2 Eine Schnittstelle zu einer sortierten Liste, in die die gefilterten Dateieinträge eingefügt werden.

## Ausgänge

* **udiFilesInDirectory:** UDINT Die Gesamtanzahl der Dateien im Verzeichnis.
* **udiDirectoriesInDirectory:** UDINT Die Anzahl der Verzeichnisse im Verzeichnis.
* **udiFilteredFilesInDirectory:** UDINT Die Anzahl der Dateien, die den Filterkriterien entsprechen.

## Verarbeitungslogik

1. Der FB öffnet das Verzeichnis asynchron und liest die Dateiinformationen.
2. Für jede Datei im Verzeichnis wird geprüft, ob sie die Filterkriterien erfüllt.
3. Gefilterte Dateien werden in die übergebene sortierte Liste eingefügt.
4. Der FB gibt die Anzahl der Dateien, Verzeichnisse und gefilterten Dateien zurück.

InOut:

| Scope  | Name                          | Type               | Initial                     | Inherited from |
| ------ | ----------------------------- | ------------------ | --------------------------- | -------------- |
| Input  | `xExecute`                    | `BOOL`             |                             | ETrig          |
| Output | `xDone`                       | `BOOL`             |                             | ETrig          |
| Output | `xBusy`                       | `BOOL`             |                             | ETrig          |
| Output | `xError`                      | `BOOL`             |                             | ETrig          |
| Input  | `sDirectoryName`              | `STRING(254)`      | ‘./’                        |                |
| Input  | `eSortBy`                     | SORT\_BY           | SORT\_BY.LAST\_MODIFICATION |                |
| Input  | `sContains`                   | `STRING`           | ‘.csv’                      |                |
| Input  | `itfFileList`                 | `COL.ISortedList2` |                             |                |
| Output | `udiFilesInDirectory`         | `UDINT`            |                             |                |
| Output | `udiDirectoriesInDirectory`   | `UDINT`            |                             |                |
| Output | `udiFilteredFilesInDirectory` | `UDINT`            |                             |                |
