fix bugs
Browse files- 1_app.py +0 -44
- 1_textInput.py +0 -18
- __pycache__/inference.cpython-39.pyc +0 -0
- __pycache__/outline.cpython-39.pyc +0 -0
- inference.py +1 -1
- outline.py +6 -58
- requirements.txt +8 -99
- temp.docx +0 -0
- temp.txt +16 -0
- textInput.py +2 -2
1_app.py
DELETED
@@ -1,44 +0,0 @@
|
|
1 |
-
import numpy as np
|
2 |
-
import gradio as gr
|
3 |
-
import textInput
|
4 |
-
|
5 |
-
output = []
|
6 |
-
keys = []
|
7 |
-
|
8 |
-
# css = ".output {min-height: 500px}"
|
9 |
-
|
10 |
-
|
11 |
-
with gr.Blocks(css = ".output {min-height: 500px}") as demo:
|
12 |
-
#用markdown语法编辑输出一段话
|
13 |
-
gr.Markdown("# 文本分类系统")
|
14 |
-
gr.Markdown("请选择要输入的文件或填入文本")
|
15 |
-
topic_num = gr.Number(label="主题个数")
|
16 |
-
max_length = gr.Number(label="摘要最大长度")
|
17 |
-
with gr.Tabs():
|
18 |
-
with gr.Tab("文本输入"):
|
19 |
-
text_input = gr.TextArea(lines=10)
|
20 |
-
text_button = gr.Button("生成")
|
21 |
-
|
22 |
-
with gr.Tab("文件输入"):
|
23 |
-
gr.Markdown("目前支持的格式有PDF、Word、txt")
|
24 |
-
file_input = gr.File(file_types=["text", ".pdf", ".docx"])
|
25 |
-
file_button = gr.Button("生成")
|
26 |
-
# 设置tab选项卡
|
27 |
-
with gr.Tabs():
|
28 |
-
with gr.Tab("分类页"):
|
29 |
-
text_keys_output = gr.TextArea(lines=30)
|
30 |
-
|
31 |
-
with gr.Tab("摘要页",):
|
32 |
-
#Blocks特有组件,设置所有子组件按水平排列
|
33 |
-
text_ab_output = gr.TextArea(lines=30)
|
34 |
-
|
35 |
-
with gr.Tab("下载页"):
|
36 |
-
file_txt_output = gr.File(label="txt格式")
|
37 |
-
file_docx_output = gr.File(label="docx格式")
|
38 |
-
file_pdf_output = gr.File(label="pdf格式")
|
39 |
-
# with gr.Accordion("Open for More!"):
|
40 |
-
# gr.Markdown("Look at me...")
|
41 |
-
text_button.click(textInput.text_dump_to_lines, inputs=[text_input,topic_num,max_length], outputs=[text_keys_output,text_ab_output,file_txt_output,file_docx_output,file_pdf_output])
|
42 |
-
file_button.click(textInput.file_dump_to_lines,inputs=[file_input,topic_num,max_length], outputs=[text_keys_output,text_ab_output,file_txt_output,file_docx_output,file_pdf_output])
|
43 |
-
|
44 |
-
demo.launch()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1_textInput.py
DELETED
@@ -1,18 +0,0 @@
|
|
1 |
-
import docx
|
2 |
-
from docx.oxml.ns import qn
|
3 |
-
from docx.shared import Pt,RGBColor
|
4 |
-
import fitz
|
5 |
-
import os
|
6 |
-
from fpdf import FPDF
|
7 |
-
import run
|
8 |
-
|
9 |
-
def text_dump_to_lines(text,topic_num,max_length):
|
10 |
-
lines = [x.strip() for x in text.split("\n") if x.strip()!='']
|
11 |
-
sentences = run.texClear(lines)
|
12 |
-
keys, output = run.textToAb(sentences,lines,int(topic_num),int(max_length))
|
13 |
-
keysText = "\n".join(keys)
|
14 |
-
outputText = "\n".join(output)
|
15 |
-
# text = "\n".join(lines)
|
16 |
-
# return text, text, dump_to_txt(lines), dump_to_docx(lines), dump_to_pdf(lines)
|
17 |
-
return keysText, outputText, dump_to_txt(output), dump_to_docx(output), dump_to_pdf(output)
|
18 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
__pycache__/inference.cpython-39.pyc
CHANGED
Binary files a/__pycache__/inference.cpython-39.pyc and b/__pycache__/inference.cpython-39.pyc differ
|
|
__pycache__/outline.cpython-39.pyc
CHANGED
Binary files a/__pycache__/outline.cpython-39.pyc and b/__pycache__/outline.cpython-39.pyc differ
|
|
inference.py
CHANGED
@@ -39,7 +39,7 @@ def predict(model,device,text):
|
|
39 |
|
40 |
def inference_matrix(topics):
|
41 |
device = torch.device('cuda' if cuda.is_available() else 'cpu')
|
42 |
-
load_path = "
|
43 |
model = torch.load(load_path,map_location=torch.device(device))
|
44 |
matrix = np.zeros([len(topics),len(topics)],dtype=float)
|
45 |
for i,i_text in enumerate(topics):
|
|
|
39 |
|
40 |
def inference_matrix(topics):
|
41 |
device = torch.device('cuda' if cuda.is_available() else 'cpu')
|
42 |
+
load_path = "bert_model.pkl"
|
43 |
model = torch.load(load_path,map_location=torch.device(device))
|
44 |
matrix = np.zeros([len(topics),len(topics)],dtype=float)
|
45 |
for i,i_text in enumerate(topics):
|
outline.py
CHANGED
@@ -1,122 +1,70 @@
|
|
1 |
import numpy as np
|
2 |
-
from scipy.cluster.hierarchy import linkage, fcluster, dendrogram
|
3 |
import matplotlib.pyplot as plt
|
4 |
import numpy as np
|
5 |
|
6 |
def find_parent(matrix, node):
|
7 |
-
# 获取该节点的所有可能的父节点及其概率
|
8 |
parents = matrix[:, node]
|
9 |
-
# 找出其中概率最大的父节点
|
10 |
max_parent = np.argmax(parents)
|
11 |
-
# 如果该父节点的概率不为零,那么返回该父节点
|
12 |
if parents[max_parent] > 0:
|
13 |
return max_parent
|
14 |
-
# 否则,返回None,表示该节点没有父节点
|
15 |
else:
|
16 |
return None
|
17 |
|
18 |
|
19 |
def find_tree(matrix, node, depth=1, children=[], max_depth=1, visited=set()):
|
20 |
-
# 定义一个空列表,用来存储结果
|
21 |
result = []
|
22 |
-
# 调用find_parent函数,找出该节点的最可能的父节点
|
23 |
parent = find_parent(matrix, node)
|
24 |
-
# 如果该父节点存在,且不在visited中
|
25 |
if parent is not None and parent not in visited:
|
26 |
-
# 将该父子关系添加到结果列表中
|
27 |
result.append([parent, node])
|
28 |
-
# 遍历当前节点的所有子节点
|
29 |
for child in children:
|
30 |
-
# 将该子节点和当前节点的关系也添加到结果列表中
|
31 |
result.append([node, child])
|
32 |
-
# 如果当前深度小于最大深度,那么递归地调用find_tree函数,传入概率矩阵和该父节点作为参数,并将深度加一
|
33 |
if depth < max_depth:
|
34 |
-
# 将当前节点添加到visited中
|
35 |
visited.add(node)
|
36 |
-
# 递归调用find_tree函数,并将visited传入
|
37 |
result.extend(find_tree(matrix, parent, depth + 1, visited=visited))
|
38 |
# 返回结果列表
|
39 |
return result
|
40 |
|
41 |
-
#
|
42 |
def find_prob(tree, matrix):
|
43 |
-
# 定义一个变量,用来存储概率,初始值为1
|
44 |
prob = 1
|
45 |
-
# 遍历树形结构中的每个父子关系
|
46 |
for parent, child in tree:
|
47 |
-
# 将该父子关系对应的概率乘到变量上
|
48 |
prob *= matrix[parent][child]
|
49 |
-
# 返回最终的概率
|
50 |
return prob
|
51 |
|
52 |
-
# 定义一个函数,它接受一个概率矩阵和一个k值作为参数,然后返回前k个最可能的森林及其概率
|
53 |
def find_forests(matrix, k):
|
54 |
-
# 定义一个空字典,用来存储每个森林及其概率
|
55 |
forests = {}
|
56 |
-
# 遍历所有的节点
|
57 |
for i in range(len(matrix)):
|
58 |
-
# 获取该节点的所有可能的子节点及其概率
|
59 |
children = matrix[i]
|
60 |
-
# 定义一个空列表,用来存储该节点的所有子节点
|
61 |
child_list = []
|
62 |
-
# 遍历所有的子节点
|
63 |
for j in range(len(children)):
|
64 |
-
# 如果子节点的概率不为零
|
65 |
if children[j] > 0:
|
66 |
-
# 将该子节点添加到列表中
|
67 |
child_list.append(j)
|
68 |
-
# 调用find_tree函数,传入概率矩阵、当前节点和子节点列表作为参数,并将返回的结果赋值给tree
|
69 |
tree = find_tree(matrix, i, children=child_list)
|
70 |
-
tree = tuple([tuple(x) for x in tree])
|
71 |
if tree:
|
72 |
-
# 调用find_prob函数,传入tree作为参数,并将返回的结果赋值给prob
|
73 |
prob = find_prob(tree, matrix)
|
74 |
-
|
75 |
-
|
76 |
-
# 那么将prob加到字典的值上,表示该树形结构出现了多次
|
77 |
-
forests[tuple(tree)] += prob # 将tree转换为元组
|
78 |
-
# 否则,即该树形结构是第一次被添加
|
79 |
else:
|
80 |
-
|
81 |
-
forests[tuple(tree)] = prob # 将tree转换为元组
|
82 |
-
# 将字典按照值降序排序,得到一个列表,每个元素是一个键值对的元组
|
83 |
sorted_forests = sorted(forests.items(), key=lambda x: x[1], reverse=True)
|
84 |
-
# 返回列表的第一个元素,即最可能的森林及其概率
|
85 |
forest, prob = sorted_forests[0]
|
86 |
-
# 定义一个空字典,用来存储带有层级结构的森林
|
87 |
result = {}
|
88 |
# 遍历森林中的每个树形结构
|
89 |
for parent, child in forest:
|
90 |
-
|
91 |
if parent in result:
|
92 |
-
# 那么将当前子节点添加到父节点对应的值中,即该父节点的子节点列表中
|
93 |
result[parent].append(child)
|
94 |
-
# 否则,即该父节点是第一次出现
|
95 |
else:
|
96 |
-
# 那么将父节点和当前子节点作为键值对添加到字典中,即创建一个新的子节点列表
|
97 |
result[parent] = [child]
|
98 |
-
# ���回带有层级结构的字典和概率
|
99 |
return result, prob
|
100 |
def passage_outline(matrix,sentences):
|
101 |
|
102 |
-
# Z = linkage(matrix, method="average")
|
103 |
-
# median = np.median(matrix)
|
104 |
-
# print(median)
|
105 |
-
# print('yes')
|
106 |
-
# labels = fcluster(Z, t=median, criterion="distance")
|
107 |
-
# print(labels)
|
108 |
-
# 调用函数,传入概率矩阵作为参数,并且指定最大深度为1
|
109 |
result, prob = find_forests(matrix, 1)
|
110 |
-
# 打印结果字典和概率
|
111 |
print(result, prob)
|
112 |
-
# 根据簇标签和主题句子生成文章结构
|
113 |
structure = {}
|
114 |
for each in result.keys():
|
115 |
structure[each] =[sentences[i] for i in result[each]]
|
116 |
-
# for label, sentence in zip(result.keys(), sentences):
|
117 |
-
# if label not in structure:
|
118 |
-
# structure[label] = []
|
119 |
-
# structure[label].append(sentence)
|
120 |
outline = ""
|
121 |
outline_list = []
|
122 |
for key in sorted(structure.keys()):
|
|
|
1 |
import numpy as np
|
|
|
2 |
import matplotlib.pyplot as plt
|
3 |
import numpy as np
|
4 |
|
5 |
def find_parent(matrix, node):
|
|
|
6 |
parents = matrix[:, node]
|
|
|
7 |
max_parent = np.argmax(parents)
|
|
|
8 |
if parents[max_parent] > 0:
|
9 |
return max_parent
|
|
|
10 |
else:
|
11 |
return None
|
12 |
|
13 |
|
14 |
def find_tree(matrix, node, depth=1, children=[], max_depth=1, visited=set()):
|
|
|
15 |
result = []
|
|
|
16 |
parent = find_parent(matrix, node)
|
|
|
17 |
if parent is not None and parent not in visited:
|
|
|
18 |
result.append([parent, node])
|
|
|
19 |
for child in children:
|
|
|
20 |
result.append([node, child])
|
|
|
21 |
if depth < max_depth:
|
|
|
22 |
visited.add(node)
|
|
|
23 |
result.extend(find_tree(matrix, parent, depth + 1, visited=visited))
|
24 |
# 返回结果列表
|
25 |
return result
|
26 |
|
27 |
+
#
|
28 |
def find_prob(tree, matrix):
|
|
|
29 |
prob = 1
|
|
|
30 |
for parent, child in tree:
|
|
|
31 |
prob *= matrix[parent][child]
|
|
|
32 |
return prob
|
33 |
|
|
|
34 |
def find_forests(matrix, k):
|
|
|
35 |
forests = {}
|
|
|
36 |
for i in range(len(matrix)):
|
|
|
37 |
children = matrix[i]
|
|
|
38 |
child_list = []
|
|
|
39 |
for j in range(len(children)):
|
|
|
40 |
if children[j] > 0:
|
|
|
41 |
child_list.append(j)
|
|
|
42 |
tree = find_tree(matrix, i, children=child_list)
|
43 |
+
tree = tuple([tuple(x) for x in tree])
|
44 |
if tree:
|
|
|
45 |
prob = find_prob(tree, matrix)
|
46 |
+
if tuple(tree) in forests:
|
47 |
+
forests[tuple(tree)] += prob
|
|
|
|
|
|
|
48 |
else:
|
49 |
+
forests[tuple(tree)] = prob
|
|
|
|
|
50 |
sorted_forests = sorted(forests.items(), key=lambda x: x[1], reverse=True)
|
|
|
51 |
forest, prob = sorted_forests[0]
|
|
|
52 |
result = {}
|
53 |
# 遍历森林中的每个树形结构
|
54 |
for parent, child in forest:
|
55 |
+
|
56 |
if parent in result:
|
|
|
57 |
result[parent].append(child)
|
|
|
58 |
else:
|
|
|
59 |
result[parent] = [child]
|
|
|
60 |
return result, prob
|
61 |
def passage_outline(matrix,sentences):
|
62 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
63 |
result, prob = find_forests(matrix, 1)
|
|
|
64 |
print(result, prob)
|
|
|
65 |
structure = {}
|
66 |
for each in result.keys():
|
67 |
structure[each] =[sentences[i] for i in result[each]]
|
|
|
|
|
|
|
|
|
68 |
outline = ""
|
69 |
outline_list = []
|
70 |
for key in sorted(structure.keys()):
|
requirements.txt
CHANGED
@@ -1,109 +1,18 @@
|
|
1 |
-
aiohttp==3.8.4
|
2 |
-
aiosignal==1.3.1
|
3 |
-
anyio==3.7.0
|
4 |
-
astor==0.8.1
|
5 |
-
async-timeout==4.0.2
|
6 |
-
attrs==23.1.0
|
7 |
-
Babel==2.12.1
|
8 |
backoff==2.2.1
|
9 |
-
|
10 |
-
|
11 |
-
|
12 |
-
charset-normalizer==3.1.0
|
13 |
-
click==8.1.3
|
14 |
-
cmake==3.26.3
|
15 |
-
colorama==0.4.6
|
16 |
-
colorlog==6.7.0
|
17 |
-
contourpy==1.0.7
|
18 |
-
cycler==0.11.0
|
19 |
-
datasets==2.12.0
|
20 |
-
decorator==5.1.1
|
21 |
-
dill==0.3.4
|
22 |
-
exceptiongroup==1.1.1
|
23 |
-
fastapi==0.95.2
|
24 |
-
filelock==3.12.0
|
25 |
-
Flask==2.3.2
|
26 |
-
Flask-Babel==2.0.0
|
27 |
-
fonttools==4.39.4
|
28 |
-
frozenlist==1.3.3
|
29 |
-
fsspec==2023.5.0
|
30 |
-
future==0.18.3
|
31 |
gensim==4.3.1
|
32 |
-
|
33 |
-
huggingface-hub==0.14.1
|
34 |
-
idna==3.4
|
35 |
-
importlib-metadata==6.6.0
|
36 |
-
importlib-resources==5.12.0
|
37 |
-
itsdangerous==2.1.2
|
38 |
jieba==0.42.1
|
39 |
-
Jinja2==3.1.2
|
40 |
-
joblib==1.2.0
|
41 |
-
kiwisolver==1.4.4
|
42 |
-
lit==16.0.5
|
43 |
-
markdown-it-py==2.2.0
|
44 |
-
MarkupSafe==2.1.2
|
45 |
matplotlib==3.7.1
|
46 |
-
mdurl==0.1.2
|
47 |
-
mpmath==1.3.0
|
48 |
-
multidict==6.0.4
|
49 |
-
multiprocess==0.70.12.2
|
50 |
-
networkx==3.1
|
51 |
numpy==1.24.3
|
52 |
-
nvidia-cublas-cu11==11.10.3.66
|
53 |
-
nvidia-cuda-cupti-cu11==11.7.101
|
54 |
-
nvidia-cuda-nvrtc-cu11==11.7.99
|
55 |
-
nvidia-cuda-runtime-cu11==11.7.99
|
56 |
-
nvidia-cudnn-cu11==8.5.0.96
|
57 |
-
nvidia-cufft-cu11==10.9.0.58
|
58 |
-
nvidia-curand-cu11==10.2.10.91
|
59 |
-
nvidia-cusolver-cu11==11.4.0.1
|
60 |
-
nvidia-cusparse-cu11==11.7.4.91
|
61 |
-
nvidia-nccl-cu11==2.14.3
|
62 |
-
nvidia-nvtx-cu11==11.7.91
|
63 |
-
opt-einsum==3.3.0
|
64 |
-
packaging==23.1
|
65 |
-
paddle-bfloat==0.1.7
|
66 |
-
paddle2onnx==1.0.6
|
67 |
-
paddlefsl==1.1.0
|
68 |
paddlenlp==2.5.2
|
69 |
-
paddlepaddle==2.4.2
|
70 |
pandas==2.0.2
|
71 |
-
|
72 |
-
|
73 |
-
|
74 |
-
|
75 |
-
pydantic==1.10.8
|
76 |
-
Pygments==2.15.1
|
77 |
-
pyparsing==3.0.9
|
78 |
-
python-dateutil==2.8.2
|
79 |
-
pytz==2023.3
|
80 |
-
PyYAML==6.0
|
81 |
-
regex==2023.5.5
|
82 |
-
requests==2.31.0
|
83 |
-
responses==0.18.0
|
84 |
-
rich==13.4.1
|
85 |
-
scikit-learn==1.2.2
|
86 |
-
scipy==1.10.1
|
87 |
-
sentencepiece==0.1.99
|
88 |
-
seqeval==1.2.2
|
89 |
-
six==1.16.0
|
90 |
-
smart-open==6.3.0
|
91 |
-
sniffio==1.3.0
|
92 |
-
starlette==0.27.0
|
93 |
-
sympy==1.12
|
94 |
-
threadpoolctl==3.1.0
|
95 |
-
tokenizers==0.13.3
|
96 |
torch==2.0.1
|
97 |
tqdm==4.65.0
|
98 |
transformers==4.29.2
|
99 |
-
triton==2.0.0
|
100 |
-
typer==0.9.0
|
101 |
-
typing-extensions==4.6.2
|
102 |
-
tzdata==2023.3
|
103 |
-
urllib3==2.0.2
|
104 |
-
uvicorn==0.22.0
|
105 |
-
visualdl==2.4.2
|
106 |
-
Werkzeug==2.3.4
|
107 |
-
xxhash==3.2.0
|
108 |
-
yarl==1.9.2
|
109 |
-
zipp==3.15.0
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
backoff==2.2.1
|
2 |
+
docx==0.2.4
|
3 |
+
fitz==0.0.1.dev2
|
4 |
+
fpdf==1.7.2
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
5 |
gensim==4.3.1
|
6 |
+
gradio==3.34.0
|
|
|
|
|
|
|
|
|
|
|
7 |
jieba==0.42.1
|
|
|
|
|
|
|
|
|
|
|
|
|
8 |
matplotlib==3.7.1
|
|
|
|
|
|
|
|
|
|
|
9 |
numpy==1.24.3
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
10 |
paddlenlp==2.5.2
|
|
|
11 |
pandas==2.0.2
|
12 |
+
PyMuPDF==1.22.3
|
13 |
+
python_docx==0.8.11
|
14 |
+
Requests==2.31.0
|
15 |
+
scikit_learn==1.2.2
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
16 |
torch==2.0.1
|
17 |
tqdm==4.65.0
|
18 |
transformers==4.29.2
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
temp.docx
ADDED
Binary file (40.6 kB). View file
|
|
temp.txt
ADDED
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# 主题:
|
2 |
+
## 计算机科学与技术在现代教育中的应用 1.从教学方面来看,教师不仅可以利用电脑和互联网以及多种课程支持
|
3 |
+
计算机科学与技术在现代教育中的应用 1.从教学方面来看,教师不仅可以利用电脑和互联网以及多种课程支持软件,提供丰富多彩的课堂内容,而且可以通过投影仪、多媒体幻灯片和电视等技术来辅助教学、展示多样性以及改进课堂氛围,以帮助提高学生的学习兴趣。考试方面,计算机科学与技术也可以发挥独特的作用,比如,通过计算机在线考试系统来更好地实施考试,使考试结果更准确、及时;而且,在考试中加入计算机图形,有助于将考试难度提高,从而更好地测试学生的思维能力。例如,学校可以利用电脑系统开发和管理学生的作业和测验,提供准确的评估机制和工具,并且能够帮助学生更好地学习和理解学科知识。不仅如此,计算机技术还可以通过开放式教育、网络教学形式等方式改进常规的教学与学习模式,从而提升教育质量。带有计算机技术的教室可以更好地提升学生的学习体验,让学生能够了解复杂的概念,从而对学科有更深入的理解。同时,计算机科学可以为学校和家庭提供有效的学习渠道,让学生从最舒适的环境中接受教育,激发学生的更多想象力和创造力。1.使用计算机技术,教师可以为学生提供更多有趣的学习方式,丰富课程、带来新的学习方式。在教学中,计算机科学与技术可以使教学变得生动有趣自然,尤其是对于跨学科的课程,而且教师可以更轻松地与学生进行交流,使学生了解知识的更多细节,并为学生提出困惑的问题和解决可能存在的问题。此外,教师可以使用网络资源来激发学生的学习兴趣,从而提高学生对课程的学习兴趣。计算机技术在教育中的拓展视野和使用方式变得越来越广泛。计算机可以作为通讯工具,连接教师和学生之间,通过电子邮件、网络学习平台以及虚拟互动空间等在线社区来实现教学过程的自动化,为新的教育理念提供技术支持。在线教学平台可以实现远程教学,远程教学可以不受地域限制,跨国受教,这样一个跨境学习者网络就可以形成,让教师和学生有机会正向互动,极大地拓展了学习者们的认知视野。计算机科学与技术不仅仅只是改变教育理念,还可以帮助学习者们更好的执行学习计划,学习分析 2.此外,计算机科学技术还可以通过社交媒体大大节省学习者与教师之间的交流时间,使教师可以精准地帮助学生解决学习中遇到的难题。
|
4 |
+
## 2 探索技术 计算机科学与技术已经成为现代教育领域中越来越重要的部分。
|
5 |
+
增强效率 计算机科学与技术的应用可以在现代教育中大大增强教学和学习的效率。1.计算机技术可以用于从基础到较高水平的各种学习成果的测量。此外,CST还可以帮助学生学习现代技术。2 探索技术 计算机科学与技术已经成为现代教育领域中越来越重要的部分。例如,它可以帮助学生学习新技能,包括计算机编程,图形设计,信息技术以及许多其他领域。计算机科学和技术还可以为学生带来更加丰富的学习体验。此外,计算机科学技术还可以为学生带来可持续的学习体验,以及更遥远的跨文化交流机会。让我们共同努力,使计算机科学和技术发挥最大的社会效应,为人类发展服务。
|
6 |
+
## 在学习方面,学生可以通过网络课程或通过互联网查阅各种信息来获取知识,大大增强学习的效率和效果;此外,
|
7 |
+
在学习方面,学生可以通过网络课程或通过互联网查阅各种信息来获取知识,大大增强学习的效率和效果;此外,学生也可以利用图形配文工具,进一步帮助让文字表达更加明确,使推理更加简单和便捷。
|
8 |
+
## 因此,计算机科学与技术对当今的教育有着重要的意义和影响。
|
9 |
+
1 方便高效的教学 计算机科学是认知科学研究的主要领域之一,它主要研究信息处理和控制的机制,而技术代表了手段、方式和手段。由此可见,计算机科学与技术对于现代教育显然是至关重要的,它们不仅具有极大的潜力,而且可以为教育活动提供有效、高效的支持。总之,计算机科学和技术在现代教育中发挥着至关重要的作用。因此,计算机科学与技术对当今的教育有着重要的意义和影响。
|
10 |
+
## 在未来,计算机科学与技术将继续发挥重要作用,促进发展学科教育,推动教育革新。
|
11 |
+
它们不仅改变了现代教育的局面,提供了更为有效和高效的教学办法,而且同时可以为学生和家长带来更多种可能性,提高全社会的教育素质。在未���,计算机科学与技术将继续发挥重要作用,促进发展学科教育,推动教育革新。2 提高教学质量 在当今的社会,计算机科学与技术已成为教育的一个重要组成部分,甚至有助于提高当今教育的质量。此外,教师也可以使用计算机技术来节省自己的工作时间,减少课堂的压力,提高教学的质量和效率。拓展视野 计算机科学与技术在现代教育中已经广泛应用,从初中到高等教育都可以看出其影响的足迹。在现代课程体系中,CST有着广泛的应用。在学校里,机器学习(ML)课程可以帮助学生在使用技术的同时加强基础的数学能力,加深学生对数学的理解。现在,许多社会都在使用一些前沿技术,如机器人,人工智能,大数据分析等,因此要掌握这些技术,掌握CST就变得更加重要。在学校的课程中,学生可以学习有关编程语言,系统管理,网络架构等内容,帮助他们更好地掌握相关技术。最后,CST还可以帮助学生牢牢把握未来社会发展的主动权。现代社会,基于信息技术的环境正在变得越来越广泛,因此对于学生来说,学习CST成为至关重要。在学校的课程体系里,针对不同的学生层次,可以提供机器学习,编程,系统管理,网络架构等知识的相关课程。随着新世纪到来,各种形式的技术不断提高,人们都在探索如何最好地使用新技术和知识来更好地教育我们的学生。计算机科学和技术可以用来支持传统的教育方法,从而改善传统的学习方式。它可以使学生针对个性化的教学目标进行自主学习。这些新技能将令学生能够更好地发挥创新的潜力,并有助于将他们的职业发展到新的高度。
|
12 |
+
## 2.光影现代化的信息技术越来越成为教学及学习的重要工具,成为一个不可缺少的教育基础设施,深刻改变了传
|
13 |
+
2.光影现代化的信息技术越来越成为教学及学习的重要工具,成为一个不可缺少的教育基础设施,深刻改变了传统教育模式,开发了教学资源和学习资源,让学习更便捷、趣味性增强,并且让课堂及学习活动更加紧凑有效,更有利于学习者们的认知过程的发展。它可以通过科技手段激发学习的兴趣,通过虚拟实践提高学习的效果,使得学习者更好地理解课程内容,增加学习的效率。
|
14 |
+
# 主题:
|
15 |
+
## 综上所述,计算机科学与技术已在现代教育中发挥着重要作用,有助于大幅提高教育的效率。
|
16 |
+
综上所述,计算机科学与技术已在现代教育中发挥着重要作用,有助于大幅提高教育的效率。对于那些精通计算机技术的教师而言,他们可以更好地把这些知识和技术纳入到课堂教学中,帮助学生更好地理解这些难以把握的概念。例如,一些计算机科学和技术的软件可以帮助学生可视化地理解这些复杂的课程和概念,他们可以以一种全新的方法去接受这些知识,也可以使他们更容易地掌握新内容。此外,在现代教育中使用技术可以更快地从一个概念转到另一个概念,教师们可以更快更有效地完成他们的课程计划。例如,可以使用在线视频来进行实时互动,也可以使用一个特定的计算机程序来解决数学问题,使学生更容易掌握数学概念。在学校里,也可以使用计算机技术支持学生的作业管理,教师可以节省时间来更有效地完成诸多任务,同时学生也可以使用聊天机器人等软件来了解和学习课程的内容。它可以为教师提供更有效的教学工具,促进他们教授新内容,同时也为学生提供新有趣的学习方式,帮助他们更好地理解它们。因此,在当今快速发展的教育环境中,计算机科学与技术的应用已经成为必不可少的有效途径。1 扩展课程范围 计算机科学与技术(CST)在现代教育中占据着重要的地位,它可以帮助学生提高他们的数学能力,掌握现代技术,从而帮助他们牢牢把握未来社会发展的主动权。首先,CST可以帮助学生增强数学素养。ML还可以让学生在开发数学方面得到更多的练习机会。CST不仅可以让他们掌握基本技术,也可以让他们熟悉信息技术产业和社会热点,为他们深入学习未来技术提供强有力的支持。总之,CST在现代教育中占据着重要的地位,可以帮助学生提高数学能力,掌握现代技术,从而牢牢把握未来社会发展的主动权。当学生拥有这样的学习能力时,他们就可以跟上社会的变化,并使自己更好地适应未来发展的趋势。2.在21世纪,计算机科学和技术在教育领域发挥着重要作用,它可以改善学习环境,使学习变得更有效率,并为学生提供独特的机会来拓宽知识面。计算机科学和技术也可以用来提高学生的技能。总而言之,计算机科学和技术为现代教育领域提供了无限的机遇,能够有效地改善教育水平,提高学生的学习能力以及技能,帮助他们获得更广阔的知识面。
|
textInput.py
CHANGED
@@ -81,7 +81,7 @@ def dump_to_docx(lines):
|
|
81 |
def dump_to_pdf(lines):
|
82 |
pdf = FPDF()
|
83 |
#读取字体文件
|
84 |
-
pdf.add_font('FZY3JW', '', '
|
85 |
pdf.add_page()
|
86 |
#设置pdf字体大小
|
87 |
pdf.set_font("FZY3JW", size=12)
|
@@ -105,7 +105,7 @@ def dump_to_pdf(lines):
|
|
105 |
return path
|
106 |
|
107 |
if __name__ == "__main__":
|
108 |
-
with open('
|
109 |
data = f.read()
|
110 |
# print(data)
|
111 |
text_dump_to_json(data,10,50)
|
|
|
81 |
def dump_to_pdf(lines):
|
82 |
pdf = FPDF()
|
83 |
#读取字体文件
|
84 |
+
pdf.add_font('FZY3JW', '', 'FZY3JW.TTF', True)
|
85 |
pdf.add_page()
|
86 |
#设置pdf字体大小
|
87 |
pdf.set_font("FZY3JW", size=12)
|
|
|
105 |
return path
|
106 |
|
107 |
if __name__ == "__main__":
|
108 |
+
with open('test.txt', 'r', encoding='utf-8') as f:
|
109 |
data = f.read()
|
110 |
# print(data)
|
111 |
text_dump_to_json(data,10,50)
|