This commit is contained in:
雷欧(林平凡)
2025-10-10 17:58:30 +08:00
parent b25906f772
commit dba361bed3

View File

@@ -443,9 +443,8 @@ private String handleTF(String input) {
* 10.10 腾锋 JY202510093195 ZQD180F-EB200 1 石**[7796] 13243039070 上海市 上海市 普陀区 水泉南路58弄3-12-502[阿15783543077转7796] 1650 有货 2
* 型号地址电话的处理逻辑不变将10.10 腾锋 JY202510093195 设置成分销标识这个字段比如之前是H-TF现在改成H-TF(10.10 腾锋 JY202510093195)
* */
if (parts.length >= 3) {
// 新增部分:处理分销标记
String fenxiaoInfo = "";
if (parts.length >= 7) { // 至少需要分销信息(3) + 型号(1) + 数量(1) + 姓名(1) + 电话(1) = 7个字段
// 处理分销标记: 取前3个字段作为分销信息
StringBuilder fenxiaoBuilder = new StringBuilder("H-TF");
StringBuilder extraInfo = new StringBuilder();
for (int i = 0; i < Math.min(3, parts.length); i++) {
@@ -459,41 +458,59 @@ private String handleTF(String input) {
if (extraInfo.length() > 0) {
fenxiaoBuilder.append("(").append(extraInfo).append(")");
}
fenxiaoInfo = fenxiaoBuilder.toString();
String fenxiaoInfo = fenxiaoBuilder.toString();
String modelNumber = parts[Math.max(0, parts.length - 5)].replace("\\n", ""); // 型号
String quantityStr = parts[Math.max(0, parts.length - 4)]; // 数量
StringBuilder address = new StringBuilder();
// 使用正则表达式提取中文字符(常用于姓名开头
Pattern pattern = Pattern.compile("[\\u4E00-\\u9FA5]+");
String namePart = parts[Math.max(0, parts.length - 3)];
Matcher matcher = pattern.matcher(namePart);
if (matcher.find()) {
address = new StringBuilder(matcher.group());
}
String phone = parts[Math.max(0, parts.length - 2)];
// 提取型号第4个字段
String modelNumber = parts[3].replace("\\n", "");
// 提取数量第5个字段
String quantityStr = parts[4];
// 提取姓名部分第6个字段
String namePart = parts[5];
// 提取电话第7个字段
String phone = parts[6];
//从phoneWithTF随机拿一个出来
if ("13243039070".equals(phone)) {
phone = phoneWithTF.get(new Random().nextInt(phoneWithTF.size()));
}
address.append(phone);
System.out.println(address);
for (int i = Math.max(0, parts.length - 1); i < parts.length; i++) {
address.append(parts[i]);
// 构建地址:姓名+电话+地址信息
StringBuilder address = new StringBuilder();
// 使用正则表达式提取中文字符(常用于姓名开头)
Pattern pattern = Pattern.compile("[\\u4E00-\\u9FA5]+");
Matcher matcher = pattern.matcher(namePart);
if (matcher.find()) {
address = new StringBuilder(matcher.group());
}
address.append(phone);
// 添加地址信息从第8个字段开始的所有剩余内容
for (int i = 7; i < parts.length; i++) {
if (!parts[i].trim().isEmpty()) {
// 过滤掉纯数字的价格信息
if (!parts[i].matches("^\\d+$") && !parts[i].matches("^[有无缺]货$")) {
address.append(parts[i]);
}
}
}
String jf = productJdConfigService.getJdUrlByProductModel(modelNumber);
StringBuilder order = new StringBuilder();
order.append("").append("\n").append(fenxiaoInfo).append("\n").append(modelNumber).append("\n").append(jf).append("\n").append(quantityStr).append("\n").append(address);
outputs.add(generateOrderText(order.toString()));
} else {
outputs.add("TF 指令格式TF\t分销信息\t分销信息\t分销信息\t型号\t数量\t地址(可含其它字段) ;也支持多行,每行一条数据");
outputs.add("TF 指令格式TF\t分销信息\t分销信息\t分销信息\t型号\t数量\t姓名\t电话\t地址 ;也支持多行,每行一条数据");
}
}
return String.join("\n\n", outputs);
}
private String handleH(String input) {
String[] lines = input.replaceFirst("^H", "").split("\n");
if (lines.length < 3) return "H 指令需三行:姓名[后缀]\n电话\n地址 … [后缀] 型号";