鸿蒙数据库表中的数据如何导出为Excel存到系统下载目录

【背景知识】

fs.write:将数据写入文件,使用promise异步回调。

DocumentViewPicker:文件选择器对象,用来支撑选择和保存各种格式文档。

逗号分隔值(Comma-Separated Values,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本)。

【解决方案】

构造Excel表格对应的CSV文件数据。

使用fs.write将数据写入Excel文件。

使用DocumentViewPicker将文件保存到用户文件目录下。

示例代码如下:

typescript 复制代码
import fs from '@ohos.file.fs';
import { picker } from '@kit.CoreFileKit';
import { BusinessError } from '@kit.BasicServicesKit';
import { hilog } from '@kit.PerformanceAnalysisKit';

const DOMAIN = 0x0000;

interface Product {
  name: string;
  price: number;
  quantity: number;
}
// 导出数据库时,此处换为查表得到的list即可
let products: Product[] = [
  { name: 'Prod,uct1', price: 10.0, quantity: 5 },
  { name: 'Pr"oduc"t2', price: 15.0, quantity: 3 }
];

@Entry
@Component
struct ExcelDemo {
  convertToCSV(data: Product[]): string {
    let headers = ["名称", "价格", "数量"];
    let fields = ["name", "price", "quantity"];
    let csvContent = headers.join("\t") + "\n";
    data.forEach((product) => {
      let rowData = fields.map(field => {
        let value: string = Object(product)[field].toString() || ''; // 获取字段值
        // 移除换行符
        value = value.toString().replace(/[\n\r]/g, ' ');
        // 如果值中包含逗号、引号,则用双引号包裹,并且转义双引号
        if (typeof value === 'string' && (value.includes(',') || value.includes('"'))) {
          let temp = value.replace(/"/g, '""');
          value = `"${temp}"`;
        }
        return value;
      });
      csvContent += rowData.join("\t") + "\n";
    });
    return csvContent;
  }

  build() {
    RelativeContainer() {
      Button('write excel').onClick(() => {
        // 定义文件路径,这里假设要保存到应用的内部存储某个目录下,可根据实际需求调整。
        try {
          let uris: Array<string> = [];
          // 创建文件管理器选项实例
          const documentSaveOptions = new picker.DocumentSaveOptions();
          documentSaveOptions.newFileNames = ["Test20.xlsx"];
          documentSaveOptions.fileSuffixChoices = ['文档|.xlsx', '.xlsx'];
          const documentViewPicker = new picker.DocumentViewPicker(getContext(this));
          // 用户选择目标文件夹,用户选择与文件类型相对应的文件夹,即可完成文件保存操作。保存成功后,返回保存文档的URI。
          documentViewPicker.save(documentSaveOptions).then((documentSaveResult: Array<string>) => {
            uris = documentSaveResult;
            let file = fs.openSync(uris[0], fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE);
            // 构建CSV数据
            let csvData = this.convertToCSV(products);
            fs.write(file.fd, csvData).then((writeLen: number) => {
              hilog.info(DOMAIN, 'testTag', 'write data to file succeed and size is:', writeLen);
            }).catch((err: BusinessError) => {
              hilog.error(DOMAIN, 'testTag',
                "write data to file failed with error message: ", err.message, ", error code: ", err.code);
            }).finally(() => {
              fs.closeSync(file);
            });

            hilog.info(DOMAIN, 'testTag', 'documentViewPicker.save to file succeed and uris are:', uris);
          }).catch((err: BusinessError) => {
            hilog.error(DOMAIN, 'testTag',
              `Invoke documentViewPicker.save failed, code is ${err.code}, message is ${err.message}`);
          })
        } catch (e) {
          hilog.error(DOMAIN, 'testTag', "documentViewPicker.save error: ", JSON.stringify(e));
        }
      })
    }
    .height('100%')
    .width('100%')
  }
}
相关推荐
BD_Marathon3 分钟前
Hive初始化元数据库时报错:Unknown version specified for initialization: 3.1.0
数据库·hive·hadoop
ArabySide11 分钟前
【Spring Boot】事务的回滚、传播与常见问题
数据库·spring boot
q***575015 分钟前
Redis服务安装自启动(Windows版)
数据库·windows·redis
Databend16 分钟前
DATA AI Databend Meetup 2025上海站邀您共话未来
数据库
白茶三许1 小时前
关于Flutter版本过低导致鸿蒙虚拟机启动失败的问题解决
flutter·开源·harmonyos·openharmony
合作小小程序员小小店1 小时前
web网页开发,在线%宠物销售%系统,基于Idea,html,css,jQuery,java,ssh,mysql。
java·前端·数据库·mysql·jdk·intellij-idea·宠物
不知更鸟1 小时前
Django 的配置文件 INSTALLED_APPS
数据库·sqlite
合作小小程序员小小店1 小时前
web网页开发,在线%物流配送管理%系统,基于Idea,html,css,jQuery,java,ssh,mysql。
java·前端·css·数据库·jdk·html·intellij-idea
2501_941142931 小时前
基于区块链的数字身份管理:探索安全与隐私的未来
网络·数据库·人工智能
LoneEon2 小时前
Ubuntu 上搭建 Redis 3 节点集群(6 实例:3主3从)
数据库·redis·缓存