Files
l-s/README.md
2025-11-21 00:52:15 +08:00

58 lines
2.2 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# l-s
为任意文件或文件夹生成和校验元数据meta 信息)的工具。
## 使用说明
程序接受一个命令行参数,作为文件或文件夹路径。如果未提供参数,则默认处理当前目录。
元数据信息以 json 格式保存且采用美观pretty打印以方便阅读。
**如果输入的是文件:**
- 元数据文件与原文件同名,仅添加 `.json` 扩展名,存放在文件所在目录下的 `meta` 子文件夹内(文件夹不存在则自动创建)。
- 若不存在相应元数据文件,则自动计算并保存。
- 若元数据文件已存在,则仅校验其中的 `xxh128` 哈希值。
- 校验通过将提示“校验通过”。
- 校验不通过时,会重新计算并输出当前元数据到标准输出,同时保留原元数据文件不变。
**如果输入的是文件夹:**
- 若不存在`meta.json`,则按字母序遍历目录树,计算全部文件元数据并写入`meta.json`
-`meta.json`已存在:
- 程序会先将其重命名为`meta-old.json`,提示用户正在校验旧数据;
- 遍历当前目录结构,仅计算每个文件的`xxh128`并与旧元数据对比;
- 发现校验失败、新增或缺失的文件都会即时打印到标准输出;
- 若全部一致,则将`meta-old.json`重命名回`meta.json`;如有异常则保留`meta-old.json`供排查(不会生成新的`meta.json`)。
标准`meta.json`的格式如下:
```json
{
"dir_name": "test",
"dirs": [
{
"dir_name": "child",
"dirs": [],
"files": [
{
"basename": "233",
"size": 4,
"friendly_size": "4.00B",
"mtime": 1763654099,
"head_115": "28AAB5A575FA1138E2CE5B1366AE697685775011",
"head_baidu": "1490AAA92CB684B2110DDB29D7A1AC15",
"ed2k": "6CB03133656BDB8DFC780EBBD4FF47CC",
"md5": "9F3D9739B11C2A4B08EA48512AC467F6",
"sha1": "10E25C6EC9A30C731BF82E5DBA37BC693E9F615D",
"sha256": "5F8064636753265C7F1B1EE075DF77E1AE9BCE7E94831DE583784A0C13EB902F",
"xxh128": "B92C6051418D532F7E933C08C44C4C88"
}
]
}
],
"files": [],
"v": "2022-10-24"
}
```