-
Notifications
You must be signed in to change notification settings - Fork 80
/
zhihu-questions.ts
executable file
·56 lines (44 loc) · 1.77 KB
/
zhihu-questions.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#!/usr/bin/env -S deno run --unstable --allow-net --allow-read --allow-write --import-map=import_map.json
// Copyright 2020 justjavac(迷渡). All rights reserved. MIT license.
import { format } from "std/datetime/mod.ts";
import { join } from "std/path/mod.ts";
import { exists } from "std/fs/mod.ts";
// import { config } from 'dotenv/mod.ts'
import type { Question, ZhihuQuestionList } from "./types.ts";
import {
createArchive4Question,
createReadme4Question,
mergeQuestions,
} from "./utils.ts";
const response = await fetch(
"https://www.zhihu.com/api/v3/feed/topstory/hot-lists/total?limit=100",
);
if (!response.ok) {
console.error(response.statusText);
Deno.exit(-1);
}
const result: ZhihuQuestionList = await response.json();
const questions: Question[] = result.data.map((x) => ({
title: x.target.title,
url: `https://www.zhihu.com/question/${x.target.id}`,
}));
const yyyyMMdd = format(new Date(), "yyyy-MM-dd");
const fullPath = join("raw/zhihu-questions", `${yyyyMMdd}.json`);
let questionsAlreadyDownload: Question[] = [];
if (await exists(fullPath)) {
const content = await Deno.readTextFile(fullPath);
questionsAlreadyDownload = JSON.parse(content);
}
const questionsAll = mergeQuestions(questions, questionsAlreadyDownload);
export const zhihuQuestionData = questionsAll;
export async function zhihuQuestions() {
// 保存原始数据
await Deno.writeTextFile(fullPath, JSON.stringify(questionsAll));
// 更新 README.md
const readme = await createReadme4Question(questionsAll);
await Deno.writeTextFile("./README.md", readme);
// 更新 archives
const archiveText = createArchive4Question(questionsAll, yyyyMMdd);
const archivePath = join("archives/zhihu-questions", `${yyyyMMdd}.md`);
await Deno.writeTextFile(archivePath, archiveText);
}