使用to_json时设置数字格式

问题描述

使用to_json时是否可以设置数字格式?

例如此代码

Seq((1,1.1),(2,1e10))
  .toDF("id","data")
  .withColumn("json",to_json(struct('data)))
  .show()

打印

+---+------+---------------+
| id|  data|           json|
+---+------+---------------+
|  1|   1.1|   {"data":1.1}|
|  2|1.0E10|{"data":1.0E10}|
+---+------+---------------+

但我想得到

+---+------+--------------------+
| id|  data|                json|
+---+------+--------------------+
|  1|   1.1|        {"data":1.1}|
|  2|1.0E10|{"data":10000000000}|
+---+------+--------------------+

直接使用Jackson时,可以按照this answer中所述为Double值设置序列化程序。使用Spark的to_json函数时,有没有办法获得相同的结果?似乎没有JSONOption可以控制数字格式。

看看JacksonGenerator代码,似乎在此line中发生了序列化。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)