excel 文件流getvalue 获取的byte python转换成str 在js怎么转成btye 并设置到Blob
时间: 2024-02-09 19:09:09 浏览: 114
对于这个问题,我建议你按照以下步骤操作:
1. 在 Python 中使用 `openpyxl` 库打开 Excel 文件,并读取需要的单元格内容,将其转换为字符串;
2. 将字符串转换为字节数组,可以使用 Python 自带的 `encode()` 方法;
3. 在 JavaScript 中,使用 `Uint8Array` 对象创建一个表示字节数组的数组;
4. 使用 `Blob` 类型创建一个二进制数据对象,并将上一步创建的字节数组设置为其数据;
5. 最后,将该 Blob 对象作为参数传入 `window.URL.createObjectURL()` 函数中,以创建一个 URL 对象,可以将其用于下载或展示数据。
以下是示例代码:
```python
import openpyxl
# 打开 Excel 文件
wb = openpyxl.load_workbook('test.xlsx')
# 获取单元格的值,并将其转换为字符串
value = str(wb['Sheet1']['A1'].value)
# 将字符串编码成字节数组
byte_array = value.encode()
```
```javascript
// 创建一个与字节数组大小相等的 Uint8Array 对象
let uint8Array = new Uint8Array(byte_array.length)
// 将字节数组的值写入 Uint8Array 数组中
for (let i = 0; i < byte_array.length; i++) {
uint8Array[i] = byte_array[i]
}
// 创建一个二进制数据对象
let blob = new Blob([uint8Array], {type: 'application/octet-stream'})
// 通过 URL.createObjectURL() 函数创建一个 URL 对象
let url = window.URL.createObjectURL(blob)
// 现在你可以使用该 URL 对象下载或展示数据
console.log(url)
```
阅读全文