Langchain-Chatchat
104 строки · 6.1 Кб
1import re2from typing import List, Optional, Any3from langchain.text_splitter import RecursiveCharacterTextSplitter4import logging5
6logger = logging.getLogger(__name__)7
8
9def _split_text_with_regex_from_end(10text: str, separator: str, keep_separator: bool11) -> List[str]:12# Now that we have the separator, split the text13if separator:14if keep_separator:15# The parentheses in the pattern keep the delimiters in the result.16_splits = re.split(f"({separator})", text)17splits = ["".join(i) for i in zip(_splits[0::2], _splits[1::2])]18if len(_splits) % 2 == 1:19splits += _splits[-1:]20# splits = [_splits[0]] + splits21else:22splits = re.split(separator, text)23else:24splits = list(text)25return [s for s in splits if s != ""]26
27
28class ChineseRecursiveTextSplitter(RecursiveCharacterTextSplitter):29def __init__(30self,31separators: Optional[List[str]] = None,32keep_separator: bool = True,33is_separator_regex: bool = True,34**kwargs: Any,35) -> None:36"""Create a new TextSplitter."""37super().__init__(keep_separator=keep_separator, **kwargs)38self._separators = separators or [39"\n\n",40"\n",41"。|!|?",42"\.\s|\!\s|\?\s",43";|;\s",44",|,\s"45]46self._is_separator_regex = is_separator_regex47
48def _split_text(self, text: str, separators: List[str]) -> List[str]:49"""Split incoming text and return chunks."""50final_chunks = []51# Get appropriate separator to use52separator = separators[-1]53new_separators = []54for i, _s in enumerate(separators):55_separator = _s if self._is_separator_regex else re.escape(_s)56if _s == "":57separator = _s58break59if re.search(_separator, text):60separator = _s61new_separators = separators[i + 1:]62break63
64_separator = separator if self._is_separator_regex else re.escape(separator)65splits = _split_text_with_regex_from_end(text, _separator, self._keep_separator)66
67# Now go merging things, recursively splitting longer texts.68_good_splits = []69_separator = "" if self._keep_separator else separator70for s in splits:71if self._length_function(s) < self._chunk_size:72_good_splits.append(s)73else:74if _good_splits:75merged_text = self._merge_splits(_good_splits, _separator)76final_chunks.extend(merged_text)77_good_splits = []78if not new_separators:79final_chunks.append(s)80else:81other_info = self._split_text(s, new_separators)82final_chunks.extend(other_info)83if _good_splits:84merged_text = self._merge_splits(_good_splits, _separator)85final_chunks.extend(merged_text)86return [re.sub(r"\n{2,}", "\n", chunk.strip()) for chunk in final_chunks if chunk.strip()!=""]87
88
89if __name__ == "__main__":90text_splitter = ChineseRecursiveTextSplitter(91keep_separator=True,92is_separator_regex=True,93chunk_size=50,94chunk_overlap=095)96ls = [97"""中国对外贸易形势报告(75页)。前 10 个月,一般贸易进出口 19.5 万亿元,增长 25.1%, 比整体进出口增速高出 2.9 个百分点,占进出口总额的 61.7%,较去年同期提升 1.6 个百分点。其中,一般贸易出口 10.6 万亿元,增长 25.3%,占出口总额的 60.9%,提升 1.5 个百分点;进口8.9万亿元,增长24.9%,占进口总额的62.7%, 提升 1.8 个百分点。加工贸易进出口 6.8 万亿元,增长 11.8%, 占进出口总额的 21.5%,减少 2.0 个百分点。其中,出口增 长 10.4%,占出口总额的 24.3%,减少 2.6 个百分点;进口增 长 14.2%,占进口总额的 18.0%,减少 1.2 个百分点。此外, 以保税物流方式进出口 3.96 万亿元,增长 27.9%。其中,出 口 1.47 万亿元,增长 38.9%;进口 2.49 万亿元,增长 22.2%。前三季度,中国服务贸易继续保持快速增长态势。服务 进出口总额 37834.3 亿元,增长 11.6%;其中服务出口 17820.9 亿元,增长 27.3%;进口 20013.4 亿元,增长 0.5%,进口增 速实现了疫情以来的首次转正。服务出口增幅大于进口 26.8 个百分点,带动服务贸易逆差下降 62.9%至 2192.5 亿元。服 务贸易结构持续优化,知识密集型服务进出口 16917.7 亿元, 增长 13.3%,占服务进出口总额的比重达到 44.7%,提升 0.7 个百分点。 二、中国对外贸易发展环境分析和展望 全球疫情起伏反复,经济复苏分化加剧,大宗商品价格 上涨、能源紧缺、运力紧张及发达经济体政策调整外溢等风 险交织叠加。同时也要看到,我国经济长期向好的趋势没有 改变,外贸企业韧性和活力不断增强,新业态新模式加快发 展,创新转型步伐提速。产业链供应链面临挑战。美欧等加快出台制造业回迁计 划,加速产业链供应链本土布局,跨国公司调整产业链供应 链,全球双链面临新一轮重构,区域化、近岸化、本土化、 短链化趋势凸显。疫苗供应不足,制造业“缺芯”、物流受限、 运价高企,全球产业链供应链面临压力。 全球通胀持续高位运行。能源价格上涨加大主要经济体 的通胀压力,增加全球经济复苏的不确定性。世界银行今年 10 月发布《大宗商品市场展望》指出,能源价格在 2021 年 大涨逾 80%,并且仍将在 2022 年小幅上涨。IMF 指出,全 球通胀上行风险加剧,通胀前景存在巨大不确定性。""",98]99# text = """"""100for inum, text in enumerate(ls):101print(inum)102chunks = text_splitter.split_text(text)103for chunk in chunks:104print(chunk)105