5

Papa Parse JavaScript ライブラリを使用して、JSON オブジェクト配列を CSV に変換しています。特定の方法で CSV 列を配置する方法はありますか。

例えば; 列を次のように取得します。

OrderStatus、canOp、OpDesc、ID、OrderNumber、FinishTime、UOM、StartTime

しかし、次のように配置したい:

ID、OrderNumber、OrderStatus、StartTime、FinishTime、canOp、OpDesc、UOM

CSV が整理されていないのは、JSON データが次のようになっているためです。

json = [
{
    OrderStatus: "Good",
    canOp:"True",
    OpDesc:"Good to go",
    ID:"100",
    OrderNumber:"1000101",
    FinishTime:"20:50",
    UOM:"K",
    StartTime:"18:10"
},
...
]

ありがとう

4

2 に答える 2

7

Papa Parse では、unparse()関数 内のフィールドの順序を指定できます。

var csv = Papa.unparse({
  fields: ["ID", "OrderNumber", "OrderStatus", "StartTime", "FinishTime", "canOp", "OpDesc", "UOM"],
  data: [{
      OrderStatus: "Good",
      canOp: "True",
      OpDesc: "Good to go",
      ID: "100",
      OrderNumber: "1000101",
      FinishTime: "20:50",
      UOM: "K",
      StartTime: "18:10"
    },
    // ...
  ]
});

console.log(csv);
<script src="https://unpkg.com/papaparse@4.6.3/papaparse.min.js"></script>
<h3>See your dev console for the results</h3>

于 2015-06-23T04:32:20.020 に答える
0

json から csv に変換するためのフレームワークは必要ありません。

// fields in the order you want them
const fields = ['ID', 'OrderNumber', 'OrderStatus', 'StartTime', 'FinishTime', 'canOp', 'OpDesc', 'UOM'];
const mapper = (key, value) => value === null ? '' : value // how to handle null values
const csv = [
  fields.join(','), // header row
  ...json.map((row) => fields.map((fieldName) => JSON.stringify(row[fieldName], mapper))).join(',')
]
console.log(csv.join('\r\n'))

出力:

ID,OrderNumber,OrderStatus,StartTime,FinishTime,canOp,OpDesc,UOM
"100","1000101","Good","18:10","20:50","True","Good to go","K"
"100","1000101","Good","18:10","20:50","True","Good to go","K"
于 2015-07-21T10:18:12.480 に答える