JMeter通过BeanShell写入CSV文件中的中文乱码

在 JMeter 中通过 BeanShell 写入 CSV 文件时,如果出现中文乱码问题,通常是因为文件编码不匹配。默认情况下,FileWriter 使用的是系统默认编码(可能是 ISO-8859-1 或其他非 UTF-8 编码),而中文字符需要 UTF-8 编码才能正确显示。

以下是解决中文乱码问题的方法:


方法 1:使用 OutputStreamWriter 并指定 UTF-8 编码

FileWriter 替换为 OutputStreamWriter,并显式指定编码为 UTF-8

java 复制代码
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.IOException;

// 定义 CSV 文件路径
String csvFilePath = "C:/path/to/your/output.csv";

// 定义要写入的数据(包含中文)
String dataToWrite = "列1,列2,列3\n值1,值2,值3";

// 使用 OutputStreamWriter 并指定 UTF-8 编码
OutputStreamWriter fileWriter = null;
try {
    fileWriter = new OutputStreamWriter(new FileOutputStream(csvFilePath, true), "UTF-8"); // true 表示追加模式
    fileWriter.write(dataToWrite + "\n");
} catch (IOException e) {
    e.printStackTrace();
} finally {
    if (fileWriter != null) {
        try {
            fileWriter.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

方法 2:添加 BOM(字节顺序标记)以确保 UTF-8 编码

某些工具(如 Excel)在打开 CSV 文件时,可能需要 BOM 来正确识别 UTF-8 编码。你可以在文件开头写入 BOM。

java 复制代码
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.IOException;

// 定义 CSV 文件路径
String csvFilePath = "C:/path/to/your/output.csv";

// 定义要写入的数据(包含中文)
String dataToWrite = "列1,列2,列3\n值1,值2,值3";

// 使用 OutputStreamWriter 并指定 UTF-8 编码
OutputStreamWriter fileWriter = null;
try {
    fileWriter = new OutputStreamWriter(new FileOutputStream(csvFilePath, true), "UTF-8");

    // 如果是新文件,写入 BOM
    if (new File(csvFilePath).length() == 0) {
        fileWriter.write('\uFEFF'); // UTF-8 BOM
    }

    fileWriter.write(dataToWrite + "\n");
} catch (IOException e) {
    e.printStackTrace();
} finally {
    if (fileWriter != null) {
        try {
            fileWriter.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

方法 3:使用第三方库(如 OpenCSV)

如果你需要更复杂的 CSV 写入操作,可以使用第三方库(如 OpenCSV)。首先需要将 OpenCSV 的 JAR 文件添加到 JMeter 的 lib 目录中,然后使用以下脚本:

java 复制代码
import com.opencsv.CSVWriter;
import java.io.FileWriter;
import java.io.IOException;

// 定义 CSV 文件路径
String csvFilePath = "C:/path/to/your/output.csv";

// 定义要写入的数据(包含中文)
String[] header = {"列1", "列2", "列3"};
String[] row = {"值1", "值2", "值3"};

// 使用 OpenCSV 写入 CSV 文件
CSVWriter csvWriter = null;
try {
    csvWriter = new CSVWriter(new OutputStreamWriter(new FileOutputStream(csvFilePath, true), "UTF-8"));

    // 如果是新文件,写入表头
    if (new File(csvFilePath).length() == 0) {
        csvWriter.writeNext(header);
    }

    // 写入数据行
    csvWriter.writeNext(row);
} catch (IOException e) {
    e.printStackTrace();
} finally {
    if (csvWriter != null) {
        try {
            csvWriter.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

方法 4:确保 JMeter 脚本本身的编码为 UTF-8

如果 BeanShell 脚本中直接包含中文字符,确保 JMeter 的脚本文件保存为 UTF-8 编码:

  1. 打开 JMeter 的 jmeter.properties 文件。

  2. 找到 sampleresult.default.encoding 属性,将其设置为 UTF-8

    properties 复制代码
    sampleresult.default.encoding=UTF-8
  3. 保存并重启 JMeter。


总结

  • 推荐使用 方法 1方法 2 ,通过 OutputStreamWriter 指定 UTF-8 编码解决中文乱码问题。
  • 如果需要更复杂的 CSV 操作,可以使用 方法 3(OpenCSV)。
  • 确保 JMeter 脚本文件本身保存为 UTF-8 编码(方法 4)。
相关推荐
Sammyyyyy17 分钟前
Node.js 是怎么一步步撼动PHP地位的
开发语言·node.js·php
lly20240622 分钟前
Node.js 路由
开发语言
程序员编程指南37 分钟前
Qt 多线程调试技巧与常见问题
c语言·开发语言·c++·qt
程序媛一枚~39 分钟前
使用Python,OpenCV计算跑图的图像彩色度
开发语言·python·opencv
golitter.1 小时前
python中的 @dataclass
开发语言·python
一枚小小程序员哈1 小时前
基于springboot的零食商城的设计与实现/零食销售系统的设计与实现
java·spring boot·spring·tomcat·maven
LiuYiCheng1234561 小时前
WebCrawler库:从网页抓取到智能处理的Python利器
开发语言·python
qqxhb1 小时前
零基础数据结构与算法——第六章:算法设计范式与高级主题-设计技巧(上)
java·数据结构·算法·分解·空间换时间·时空平衡
野生技术架构师1 小时前
系统改造:一次系统领域拆分的实战复盘
java·大数据·开发语言
南玖yy1 小时前
C++多态:面向对象编程的灵魂之
运维·开发语言·数据库·c++·后端·c·c语音