Как написать файл JSON на основе данных из нескольких файлов уценки - PullRequest
0 голосов
/ 14 июня 2019

Мне нужно создать API с данными из моих файлов уценки.

У меня есть приблизительно 100 файлов уценки с данными, подобными этим в верхней части файла:

---
title: Lorem ipsum
category: component
primaryKeywords: curved horizon
secondaryKeywords: css block content seperator
---

Желаемый выводэто единственный файл .json со всеми данными из моего файла .md в виде объектов в массиве.

Пример:

[
  {
    "title": "Lorem ipsum",
    "category": "component",
    "primaryKeywords": "curved horizon",
    "secondaryKeywords": "css block content seperator"
  },
  {
    "title": "Lorem ipsum",
    "category": "component",
    "primaryKeywords": "curved horizon",
    "secondaryKeywords": "css block content seperator"
  },
  {
    "title": "Lorem ipsum",
    "category": "component",
    "primaryKeywords": "curved horizon",
    "secondaryKeywords": "css block content seperator"
  }
]

Файл JSON должен быть создан как часть моей сборки внешнего интерфейса.Я использую gulp.

Я пытался сделать что-то вроде этого:

gulp.task('search-api', function (cb) {
  const fs = require('fs');
  const matter = require('gray-matter');
  const str = fs.readFileSync('./src/docs/01-Components/02-Layout/03-bow.md', 'utf8');
  console.log(matter(str));
});

Я могу показать данные из 1 файла в консоли, делая это.Но мне нужна помощь, чтобы показать данные из всех файлов в ./src/docs/, а затем объединить их с 1 результатом и разобрать в 1 файл JSON.

Как я могу это сделать?Все помощь и предложения приветствуются.

Ответы [ 2 ]

1 голос
/ 17 июня 2019

Я сделал это как "упражнение", используя узел, а не gulp:

const fs = require('fs');
const glob = require('glob');
const os = require('os');

const markdownFiles = glob.sync("./markdown/*.md");  // an array of files in the 'markdown' directory
let finalArray = [];


function buildJSONfile() {

  let contents;

  markdownFiles.forEach((nextFile) => {

    contents = fs.readFileSync(nextFile, "UTF8");

        // os.EOL = \r\n for windows, \n for POSIX
    let grayMatter = contents.match(new RegExp(`---${os.EOL}((.*${os.EOL})*?)---`));  // get just the content between the "---"s in array[1]

    //  add quotes around all the keys and values and add commas between key:value pairs
    let addedQuotes = grayMatter[1].replace(/^([^:]*)(:\s*)(.*)(\s*)/mg, '"$1"$2"$3",');  

    addedQuotes = addedQuotes.slice(0, addedQuotes.length - 1);  // remove the extra comma at the end of the last value

    let addedBrackets = `{${addedQuotes}}`;  // add brackets around the whole thing so that we can use JSON.parse

    let JSONobject = JSON.parse(addedBrackets);

    finalArray.push(JSONobject);
  });

      // write to a file : result.json
  fs.writeFileSync("./result.json", JSON.stringify(finalArray, null, '\t'), "UTF8");
};

buildJSONfile();  // comment out if using gulp

Запуск с node yourFileNameHere.js.
Вы также можете поместить его в gulpfile.js и запустить через gulp buildJSONfile.

1 голос
/ 14 июня 2019

В основном, что вы хотите сделать, это

  1. создать writeStream
  2. добавить "["
  3. Добавить объект

  4. цикл для каждого файла: добавьте запятую ","

  5. Добавить еще один объект
    : loopend
  6. Добавить еще одно закрытие "]"

Для этого вы можете использовать пакет walk.

const fs = require('fs');
const walk = require('walk');
const matter = require('gray-matter');
const dirname = "./src/docs";
const path = require('path');
const walker = walk.walk(dirname);
let prefix = ""
const stream = fs.createWriteStream("json.json", {flags:'a'});
stream.write("[\n");
walker.on("file",  (root, fileStats, next) => {
    const str = fs.readFileSync(path.join(root, fileStats.name), 'utf8');
    stream.write(prefix);
    stream.write(JSON.stringify(matter(str),null, 4));
    prefix=","
    next();
});

walker.on("errors", function (root, nodeStatsArray, next) {
    next();
});

walker.on("end", function () {
    stream.write("\n]");
    stream.end();
});

PS: Этот код, который я сделал из головы, чтобы дать вам какой-то намек. Не стесняйтесь редактировать, если есть ошибки.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...