This commit is contained in:
Your Name
2024-06-16 23:10:08 +09:00
parent e48b81cbc6
commit 6cddab17b2
3 changed files with 58 additions and 0 deletions

BIN
.cache/mergePDFs.exe Normal file

Binary file not shown.

58
.cache/mergePDFs.go Normal file
View File

@@ -0,0 +1,58 @@
package main
import (
"io/ioutil"
"os"
"sort"
"strings"
)
func main() {
dirPath := "." // 当前目录
mergeSplitPDFsInDirectory(dirPath)
}
func mergeSplitPDFsInDirectory(dirPath string) {
files, err := ioutil.ReadDir(dirPath)
if err != nil {
panic(err)
}
splitFiles := make(map[string][]string)
for _, file := range files {
if file.IsDir() {
continue
}
fileName := file.Name()
if strings.Contains(fileName, ".pdf.") {
baseName := strings.Split(fileName, ".pdf.")[0] + ".pdf"
splitFiles[baseName] = append(splitFiles[baseName], fileName)
}
}
for baseName, parts := range splitFiles {
sort.Strings(parts) // 确保文件顺序正确
mergeFiles(baseName, parts)
}
}
func mergeFiles(baseName string, parts []string) {
mergedFile, err := os.Create(baseName)
if err != nil {
panic(err)
}
defer mergedFile.Close()
for _, part := range parts {
data, err := ioutil.ReadFile(part)
if err != nil {
panic(err)
}
_, err = mergedFile.Write(data)
if err != nil {
panic(err)
}
os.Remove(part) // 合并后删除分割文件
}
}