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)。
相关推荐
Kookoos41 分钟前
Dynamics 365 Finance + Power Automate 自动化凭证审核
运维·自动化·dynamics 365·power automate
крон2 小时前
【Auto.js例程】华为备忘录导出到其他手机
开发语言·javascript·智能手机
zh_xuan2 小时前
c++ 单例模式
开发语言·c++·单例模式
coderSong25682 小时前
Java高级 |【实验八】springboot 使用Websocket
java·spring boot·后端·websocket
老胖闲聊3 小时前
Python Copilot【代码辅助工具】 简介
开发语言·python·copilot
Blossom.1183 小时前
使用Python和Scikit-Learn实现机器学习模型调优
开发语言·人工智能·python·深度学习·目标检测·机器学习·scikit-learn
Mr_Air_Boy3 小时前
SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题
java·spring boot·后端
曹勖之3 小时前
基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
开发语言·python·机器人·ros2
豆沙沙包?4 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
军训猫猫头4 小时前
96.如何使用C#实现串口发送? C#例子
开发语言·c#