mirror of
https://github.com/CherryHQ/cherry-studio.git
synced 2025-12-19 06:30:10 +08:00
76 lines
1.9 KiB
TypeScript
76 lines
1.9 KiB
TypeScript
import { BaseLoader } from '@cherrystudio/embedjs-interfaces'
|
|
import { cleanString } from '@cherrystudio/embedjs-utils'
|
|
import { RecursiveCharacterTextSplitter } from '@langchain/textsplitters'
|
|
import { loggerService } from '@logger'
|
|
import md5 from 'md5'
|
|
import type { OfficeParserConfig } from 'officeparser'
|
|
import { parseOfficeAsync } from 'officeparser'
|
|
|
|
const logger = loggerService.withContext('OdLoader')
|
|
|
|
export enum OdType {
|
|
OdtLoader = 'OdtLoader',
|
|
OdsLoader = 'OdsLoader',
|
|
OdpLoader = 'OdpLoader',
|
|
Undefined = 'undefined'
|
|
}
|
|
|
|
export class OdLoader<OdType> extends BaseLoader<{ type: string }> {
|
|
private readonly odType: OdType
|
|
private readonly filePath: string
|
|
private extractedText: string
|
|
private config: OfficeParserConfig
|
|
|
|
constructor({
|
|
odType,
|
|
filePath,
|
|
chunkSize,
|
|
chunkOverlap
|
|
}: {
|
|
odType: OdType
|
|
filePath: string
|
|
chunkSize?: number
|
|
chunkOverlap?: number
|
|
}) {
|
|
super(`${odType}_${md5(filePath)}`, { filePath }, chunkSize ?? 1000, chunkOverlap ?? 0)
|
|
this.odType = odType
|
|
this.filePath = filePath
|
|
this.extractedText = ''
|
|
this.config = {
|
|
newlineDelimiter: ' ',
|
|
ignoreNotes: false
|
|
}
|
|
}
|
|
|
|
private async extractTextFromOdt() {
|
|
try {
|
|
this.extractedText = await parseOfficeAsync(this.filePath, this.config)
|
|
} catch (err) {
|
|
logger.error('odLoader error', err as Error)
|
|
throw err
|
|
}
|
|
}
|
|
|
|
override async *getUnfilteredChunks() {
|
|
if (!this.extractedText) {
|
|
await this.extractTextFromOdt()
|
|
}
|
|
const chunker = new RecursiveCharacterTextSplitter({
|
|
chunkSize: this.chunkSize,
|
|
chunkOverlap: this.chunkOverlap
|
|
})
|
|
|
|
const chunks = await chunker.splitText(cleanString(this.extractedText))
|
|
|
|
for (const chunk of chunks) {
|
|
yield {
|
|
pageContent: chunk,
|
|
metadata: {
|
|
type: this.odType as string,
|
|
source: this.filePath
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|