2024-08-11

在JavaScript中,可以使用第三方库来读取和导出Excel文件。一个常用的库是xlsx,它可以处理多种格式的电子表格文件。

以下是使用xlsx库的示例代码:

安装xlsx库:




npm install xlsx

读取Excel文件内容:




const XLSX = require('xlsx');
 
// 读取Excel文件
const readExcel = (file) => {
  const reader = new FileReader();
  reader.onload = (e) => {
    const data = new Uint8Array(e.target.result);
    const workbook = XLSX.read(data, { type: 'array' });
    const firstSheetName = workbook.SheetNames[0];
    const worksheet = workbook.Sheets[firstSheetName];
    const json = XLSX.utils.sheet_to_json(worksheet);
    console.log(json);
  };
  reader.readAsArrayBuffer(file);
};
 
// 假设你有一个input元素来上传文件
const input = document.getElementById('input-excel');
input.addEventListener('change', (e) => {
  const file = e.target.files[0];
  readExcel(file);
});

导出JSON数据到Excel文件:




const writeExcel = (data, fileName) => {
  const worksheet = XLSX.utils.json_to_sheet(data);
  const workbook = XLSX.utils.book_new();
  XLSX.utils.book_append_sheet(workbook, worksheet, 'Sheet1');
  
  const wbout = XLSX.write(workbook, { bookType: 'xlsx', type: 'binary' });
  function s2ab(s) {
    const buf = new ArrayBuffer(s.length);
    const view = new Uint8Array(buf);
    for (let i = 0; i !== s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
    return buf;
  }
  
  saveAs(new Blob([s2ab(wbout)], { type: 'application/octet-stream' }), fileName + '.xlsx');
};
 
// 示例数据
const jsonData = [
  { name: 'Alice', email: 'alice@example.com' },
  { name: 'Bob', email: 'bob@example.com' }
];
 
// 导出数据到Excel文件
writeExcel(jsonData, 'data');

在上面的代码中,readExcel函数用于读取用户通过<input>元素上传的Excel文件,并将其内容转换为JSON。writeExcel函数则将JSON数据导出为Excel文件,你可以通过修改jsonData变量来导出不同的数据。

注意:saveAs函数来自于file-saver库,需要单独安装:




npm install file-saver

这些代码示例假设你正在使用一个HTML页面,并且已经有相应的<input>元素来上传文件。如果你在浏览器环境中运行这些代码,请确保服务是通过HTTPS提供的,因为现代浏览器限制了从非HTTPS来源读取文件。

2024-08-10

在Java中,你可以使用org.json库或者com.google.gson库来解析和获取JSON中的值。以下是使用这两种库的示例代码。

使用org.json库:




import org.json.JSONObject;
 
public class JsonExample {
    public static void main(String[] args) {
        String jsonString = "{\"name\":\"John\", \"age\":30}";
        JSONObject jsonObject = new JSONObject(jsonString);
        String name = jsonObject.getString("name");
        int age = jsonObject.getInt("age");
        System.out.println("Name: " + name);
        System.out.println("Age: " + age);
    }
}

使用com.google.gson库:




import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
 
public class JsonExample {
    public static void main(String[] args) {
        String jsonString = "{\"name\":\"John\", \"age\":30}";
        JsonObject jsonObject = JsonParser.parseString(jsonString).getAsJsonObject();
        String name = jsonObject.get("name").getAsString();
        int age = jsonObject.get("age").getAsInt();
        System.out.println("Name: " + name);
        System.out.println("Age: " + age);
    }
}

在这两个例子中,我们都创建了一个JSON字符串,并使用相应的库解析它,然后获取了nameage字段的值。你需要在你的项目中包含对应的库才能运行这些代码。

2024-08-10



import 'package:json_annotation/json_annotation.dart';
 
part 'example.g.dart';
 
@JsonSerializable()
class Example {
  final String name;
  final int age;
 
  Example({required this.name, required this.age});
 
  factory Example.fromJson(Map<String, dynamic> json) => _$ExampleFromJson(json);
  Map<String, dynamic> toJson() => _$ExampleToJson(this);
}
 
void main() {
  final example = Example(name: 'John Doe', age: 30);
  final jsonString = example.toJson().toString();
  print(jsonString);
 
  final newExample = Example.fromJson(jsonDecode(jsonString));
  print(newExample.name);
  print(newExample.age);
}

这段代码首先导入了json_annotation包,并声明了一个part 'example.g.dart';,这是为了和生成的代码一起工作。Example类使用@JsonSerializable()注解标记,表示它可以自动序列化为JSON。该类有两个属性:nameage。构造函数中这些属性被标记为必要参数。fromJson工厂构造函数用于从JSON创建对象,toJson方法将对象转换为JSON。在main函数中,我们创建了一个Example实例,将其序列化为JSON,然后再将JSON反序列化回Example实例。

2024-08-10

在前端操作JSON,主要涉及到解析和序列化两个过程。

  1. JSON解析:

JSON解析就是将JSON字符串转换为JavaScript对象。




var jsonString = '{"name":"John", "age":30, "city":"New York"}';
var obj = $.parseJSON(jsonString);
alert( obj.name + ", " + obj.age + ", " + obj.city );
  1. JSON序列化:

JSON序列化就是将JavaScript对象转换为JSON字符串。




var obj = { name: "John", age: 30, city: "New York" };
var jsonString = JSON.stringify(obj);
alert(jsonString);
  1. 使用$.each遍历JSON对象:



var jsonString = '{"name":"John", "age":30, "city":"New York"}';
var obj = $.parseJSON(jsonString);
$.each(obj, function(key, value) {
    alert(key + " : " + value);
});
  1. 使用$.grep过滤JSON数组:



var jsonString = '[{"name":"John", "age":30}, {"name":"Anne", "age":25}]';
var obj = $.parseJSON(jsonString);
var result = $.grep(obj, function(element, index) {
    return element.age > 25;
});
alert(JSON.stringify(result));
  1. 使用$.map映射JSON数组:



var jsonString = '[{"name":"John", "age":30}, {"name":"Anne", "age":25}]';
var obj = $.parseJSON(jsonString);
var result = $.map(obj, function(element, index) {
    return element.name;
});
alert(JSON.stringify(result));
  1. 使用$.parseJSON解析JSON字符串:



var jsonString = '{"name":"John", "age":30, "city":"New York"}';
var obj = $.parseJSON(jsonString);
alert(obj.name);
  1. 使用JSON.stringify序列化JavaScript对象:



var obj = { name: "John", age: 30, city: "New York" };
var jsonString = JSON.stringify(obj);
alert(jsonString);

以上就是在前端使用jQuery操作JSON的常见方法。

2024-08-10



const Koa = require('koa');
const Router = require('koa-router');
const koaBody = require('koa-body');
 
const app = new Koa();
const router = new Router();
 
// 使用koa-body解析请求体
app.use(koaBody({
    multipart: true, // 允许文件上传
    formidable: {
        maxFileSize: 200 * 1024 * 1024 // 设置最大文件上传大小
    }
}));
 
// 文件上传API
router.post('/upload', ctx => {
    let file = ctx.request.files.file; // 获取上传的文件
    // 处理文件,例如保存文件
    // ...
    ctx.body = '文件上传成功';
});
 
// JSON数据处理API
router.post('/json', ctx => {
    let data = ctx.request.body; // 获取请求中的JSON数据
    // 处理JSON数据
    // ...
    ctx.body = 'JSON数据处理成功';
});
 
app.use(router.routes());
app.use(router.allowedMethods());
 
app.listen(3000);

这段代码演示了如何在Koa应用中使用koa-body中间件来处理文件上传和JSON数据。它创建了一个简单的应用,包含了两个API端点:/upload用于文件上传,/json用于处理JSON数据。代码中包含了文件上传的示例和JSON数据处理的示例,并展示了如何获取上传的文件和JSON数据,以及如何响应客户端。

2024-08-10

在Python中,你可以使用json模块将字典(dict)转换为JSON格式,并将其保存到文件中。以下是一个简单的例子:




import json
 
# 创建一个字典
data = {
    "name": "John",
    "age": 30,
    "city": "New York"
}
 
# 将字典转换为JSON字符串
json_data = json.dumps(data)
 
# 将JSON字符串保存到文件
with open('data.json', 'w') as f:
    json.dump(data, f)

使用json.dumps()可以将字典转换为JSON字符串,而json.dump()直接将数据写入到文件对象。这里使用了with语句来确保文件正常关闭。

2024-08-10



import json
 
# 解析JSON字符串
json_str = '{"name": "John", "age": 30, "city": "New York"}'
data = json.loads(json_str)
print(data)  # 输出: {'name': 'John', 'age': 30, 'city': 'New York'}
 
# 生成JSON字符串
data_to_json = {"name": "Jane", "age": 25, "city": "Los Angeles"}
json_str_2 = json.dumps(data_to_json)
print(json_str_2)  # 输出: {"name": "Jane", "age": 25, "city": "Los Angeles"}
 
# 将JSON数据写入文件
json_file_path = 'user_info.json'
with open(json_file_path, 'w') as json_file:
    json.dump(data_to_json, json_file)
 
# 从文件读取JSON数据
with open(json_file_path, 'r') as json_file:
    data_from_file = json.load(json_file)
print(data_from_file)  # 输出: {'name': 'John', 'age': 30, 'city': 'New York'}

这段代码展示了如何在Python中使用json模块来解析和生成JSON字符串,以及如何将JSON数据写入文件和从文件读取JSON数据。

2024-08-10

JSON_ARRAYAGG 是 MySQL 中的一个聚合函数,用于创建 JSON 数组。它将聚合行的列值,并将它们作为一个 JSON 数组中的元素返回。

以下是 JSON_ARRAYAGG 的基本使用方法:




SELECT JSON_ARRAYAGG(column_name) FROM table_name;

这将返回一个包含 table_name 表中所有行的 column_name 列值的 JSON 数组。

如果你想要对聚合的 JSON 数组进行更多的控制,你可以使用 JSON_OBJECTAGG 创建 JSON 对象,然后将 JSON_ARRAYAGG 结果作为其中的一个字段。

下面是一个具体的示例:

假设我们有一个 employees 表,它有 id, name, 和 department 列,我们想要为每个部门创建一个 JSON 数组,包含该部门的所有员工的名字。




SELECT department, JSON_ARRAYAGG(name) AS employees_list
FROM employees
GROUP BY department;

这将返回每个部门的名字数组,如下所示:




{
  "HR": ["Alice", "Bob", "Charlie"],
  "Engineering": ["David", "Ella", "Frank"],
  "Sales": ["Grace", "Irene", "Jack"]
}

在这个例子中,我们首先按 department 进行分组,然后对每个部门的 name 列使用 JSON_ARRAYAGG 聚合函数来创建包含所有员工名字的 JSON 数组。

2024-08-10

报错解释:

这个错误表明你正在尝试使用Go语言的json包将一个JSON字符串解析到Go的结构体中,但是遇到了一个问题,那就是JSON字符串中的某个值并不匹配结构体中对应字段的数据类型。具体来说,你的结构体中的.tim字段可能是一个结构体类型,而JSON字符串中对应的值是一个字符串。

解决方法:

  1. 检查JSON数据,确保JSON中对应.tim字段的值的类型与Go结构体中的字段类型相匹配。
  2. 如果.tim字段是一个结构体,确保JSON中的字符串可以被正确地解析为该结构体。
  3. 如果.tim字段应该是一个字符串,确保JSON中的值也是一个字符串。

示例:

假设你的结构体定义如下:




type MyStruct struct {
    Tim time.Time `json:"tim"`
}

而你的JSON数据是这样的:




{
    "tim": "2021-01-01"
}

你需要确保JSON中的"2021-01-01"是一个有效的时间字符串,可以被time.Time类型正确解析。如果不是,你需要修改JSON数据或者结构体中的字段类型以确保匹配。如果JSON中的值不是一个时间字符串,你可能需要在Go结构体中为该字段使用适当的类型,或者在解析之前对JSON数据进行处理。

2024-08-10



package main
 
import (
    "encoding/json"
    "fmt"
    "log"
)
 
// 定义一个结构体来表示一个用户
type User struct {
    ID   int
    Name string
    Age  int
}
 
func main() {
    // 解析JSON
    jsonStr := `{"ID":1,"Name":"张三","Age":30}`
    var user User
    err := json.Unmarshal([]byte(jsonStr), &user)
    if err != nil {
        log.Fatalf("JSON解析失败: %v", err)
    }
    fmt.Printf("解析后的用户: %+v\n", user)
 
    // 生成JSON
    user.ID = 2
    user.Name = "李四"
    user.Age = 25
    jsonBytes, err := json.Marshal(user)
    if err != nil {
        log.Fatalf("JSON生成失败: %v", err)
    }
    fmt.Printf("生成的JSON字符串: %s\n", jsonBytes)
}

这段代码首先定义了一个User结构体,用于表示用户信息。然后,它使用json.Unmarshal函数解析一个包含用户信息的JSON字符串,并打印解析后的结果。接着,它使用json.Marshal函数将User结构体的实例转换为JSON字符串并打印。这个过程展示了如何在Go语言中进行JSON的解析和生成。