ArtService.cs 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605
  1. using Azure.Cosmos;
  2. using Azure.Messaging.ServiceBus;
  3. using HTEXLib.COMM.Helpers;
  4. using Microsoft.AspNetCore.Hosting;
  5. using Microsoft.Extensions.Configuration;
  6. using Microsoft.Extensions.Hosting;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.IO;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Text.Json;
  13. using System.Threading.Tasks;
  14. using TEAMModelOS.SDK.DI;
  15. using TEAMModelOS.SDK.Extension;
  16. using TEAMModelOS.SDK.Models.Cosmos.Common;
  17. namespace TEAMModelOS.SDK.Models.Service
  18. {
  19. public static class ArtService
  20. {
  21. public static List<ArtQuota> GetParentByChildId(List<ArtQuota> quotas, string childId) {
  22. List<ArtQuota> list_quotas = new List<ArtQuota>();
  23. list_quotas = TreeToList(quotas, list_quotas, null);
  24. List<ArtQuota> parents = new List<ArtQuota>();
  25. parents = GetParents(list_quotas, parents, $"{childId}");
  26. if (parents.IsNotEmpty()) {
  27. int len = parents.Count;
  28. parents.ForEach(x => {
  29. x.level= len-x.level+1;
  30. });
  31. }
  32. return parents;
  33. }
  34. private static List<ArtQuota> GetParents(List<ArtQuota> list, List<ArtQuota> parents, string cid, int level = 1)
  35. {
  36. var child = list.Find(x => x.id.Equals(cid));
  37. if (child != null)
  38. {
  39. child.level = level;
  40. parents.Add(child);
  41. if (!child.pid.Equals(child.id))
  42. {
  43. level++;
  44. return GetParents(list, parents, child.pid, level);
  45. }
  46. else
  47. {
  48. return parents;
  49. }
  50. }
  51. else { return parents; }
  52. }
  53. private static List<ArtQuota> TreeToList(List<ArtQuota> trees, List<ArtQuota> nodes, string pid)
  54. {
  55. List<ArtQuota> list = new List<ArtQuota>();
  56. trees.ForEach(x => {
  57. var node = new ArtQuota
  58. {
  59. pid = string.IsNullOrWhiteSpace(pid) ? x.id : pid,
  60. id = x.id,
  61. name = x.name,
  62. percent = x.percent,
  63. type = x.type,
  64. };
  65. list.Add(node);
  66. });
  67. nodes.AddRange(list);
  68. foreach (ArtQuota tree in trees)
  69. {
  70. if (tree.children.IsNotEmpty())
  71. {
  72. TreeToList(tree.children, nodes, tree.id);
  73. }
  74. }
  75. return nodes;
  76. }
  77. public async static Task<List<ArtStudentPdf>> GenArtPDF(List<string> studentIds, string _artId,string _schoolId,string head_lang ,AzureCosmosFactory _azureCosmos,
  78. IWebHostEnvironment _environment, CoreAPIHttpService _coreAPIHttpService, DingDing _dingDing, AzureServiceBusFactory _serviceBus, IConfiguration _configuration) {
  79. var client = _azureCosmos.GetCosmosClient();
  80. string query = $" select value c from c where c.school = '{_schoolId}' ";
  81. if (studentIds.Any())
  82. {
  83. query = $" select value c from c where c.school = '{_schoolId}' and c.studentId in ({string.Join(",", studentIds.Select(z => $"'{z}'"))})";
  84. }
  85. List<StudentArtResult> artResults = new List<StudentArtResult>();
  86. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, Constant.Student).GetItemQueryIterator<StudentArtResult>
  87. (queryText: query, requestOptions: new QueryRequestOptions { PartitionKey = new PartitionKey($"ArtResult-{_artId}") }))
  88. {
  89. artResults.Add(item);
  90. }
  91. School school = await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, Constant.School).ReadItemAsync<School>($"{_schoolId}", new PartitionKey("Base"));
  92. string path = Path.Combine(_environment.ContentRootPath, $"Lang/{head_lang}.json");
  93. string comment1 = "";
  94. string comment2 = "";
  95. string comment3 = "";
  96. string comment4 = "";
  97. string comment5 = "";
  98. string comment_subject_music = "";
  99. string comment_subject_painting = "";
  100. var jsonDoc = readFileJson(path);
  101. if (jsonDoc != null)
  102. {
  103. if (jsonDoc.RootElement.TryGetProperty("art-template-comment1", out JsonElement _c1))
  104. {
  105. comment1 = $"{_c1}";
  106. }
  107. if (jsonDoc.RootElement.TryGetProperty("art-template-comment2", out JsonElement _c2))
  108. {
  109. comment2 = $"{_c2}";
  110. }
  111. if (jsonDoc.RootElement.TryGetProperty("art-template-comment3", out JsonElement _c3))
  112. {
  113. comment3 = $"{_c3}";
  114. }
  115. if (jsonDoc.RootElement.TryGetProperty("art-template-comment4", out JsonElement _c4))
  116. {
  117. comment4 = $"{_c4}";
  118. }
  119. if (jsonDoc.RootElement.TryGetProperty("art-template-comment5", out JsonElement _c5))
  120. {
  121. comment5 = $"{_c5}";
  122. }
  123. if (jsonDoc.RootElement.TryGetProperty("art-template-subject_music", out JsonElement _subject_music))
  124. {
  125. comment_subject_music = $"{_subject_music}";
  126. }
  127. if (jsonDoc.RootElement.TryGetProperty("art-template-subject_painting", out JsonElement _subject_painting))
  128. {
  129. comment_subject_painting = $"{_subject_painting}";
  130. }
  131. }
  132. ArtEvaluation art = await client.GetContainer(Constant.TEAMModelOS, "Common").ReadItemAsync<ArtEvaluation>($"{_artId}", new PartitionKey($"Art-{_schoolId}"));
  133. ArtSetting artSetting = await client.GetContainer(Constant.TEAMModelOS, Constant.Normal).ReadItemAsync<ArtSetting>($"{school.areaId}", new PartitionKey($"ArtSetting"));
  134. var allExamIds = art.settings.SelectMany(x => x.task).Where(z => z.type == 1);
  135. var subjects = art.subjects;
  136. //获取学校的所有艺术科目的uuid,并映射找到相应的知识点,知识块。
  137. var schoolSubjects = school.period.SelectMany(x => x.subjects).Where(s => !string.IsNullOrWhiteSpace(s.bindId) && subjects.Select(z => z.id).Contains(s.bindId));
  138. StringBuilder sql = new StringBuilder($"select value(c) from c");
  139. List<KeyValuePair<string, List<Block>>> subjectBindBlocks = new List<KeyValuePair<string, List<Block>>>();
  140. foreach (var schSub in schoolSubjects)
  141. {
  142. List<Block> blocks = new List<Block>();
  143. string code = $"Knowledge-{_schoolId}-{schSub.id}";
  144. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School")
  145. .GetItemQueryIterator<Knowledge>(queryText: sql.ToString(), requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"{code}") }))
  146. {
  147. item.blocks.ForEach(x =>
  148. {
  149. var block = blocks.Find(z => z.name.Equals(x.name));
  150. if (block != null)
  151. {
  152. block.points.AddRange(x.points);
  153. }
  154. else
  155. {
  156. blocks.Add(x);
  157. }
  158. });
  159. }
  160. subjectBindBlocks.Add(new KeyValuePair<string, List<Block>>(schSub.bindId, blocks));
  161. }
  162. List<ExamInfo> exams = new List<ExamInfo>();
  163. List<ExamResult> examResults = new();
  164. if (allExamIds.Any())
  165. {
  166. var queryExam = $"select value c from c where c.id in ({string.Join(",", allExamIds.Select(x => $"'{x.acId}'"))}) ";
  167. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "Common").GetItemQueryIterator<ExamInfo>(queryText: queryExam, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Exam-{_schoolId}") }))
  168. {
  169. exams.Add(item);
  170. }
  171. foreach (var allexamId in allExamIds)
  172. {
  173. var queryResult = $"select c.id,c.name,c.subjectId,c.studentScores,c.studentIds,c.paper,c.classes,c.sRate,c.average,c.standard,c.lostStus,c.record,c.phc,c.plc,c.examId from c where c.examId = '{allexamId.acId}' and c.subjectId = '{allexamId.subject}' ";
  174. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "Common").GetItemQueryIterator<ExamResult>(queryText: queryResult, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"ExamResult-{allexamId.acId}") }))
  175. {
  176. examResults.Add(item);
  177. }
  178. }
  179. }
  180. (List<RMember> rmembers, List<RGroupList> groups) = await GroupListService.GetMemberByListids(_coreAPIHttpService, client, _dingDing, art.classes, art.school);
  181. List<ArtStudentPdf> studentPdfs = new List<ArtStudentPdf>();
  182. artResults.ForEach(x =>
  183. {
  184. var allSubject = x.results.GroupBy(g => g.quotaId).Select(s => new { key = s.Key, list = s.ToList() }).ToList();
  185. var groupSubject = x.results.GroupBy(g => $"{g.quotaId}-{g.subjectId}").Select(s => new { key = s.Key, list = s.ToList() }).ToList();
  186. //综合-所有科目的艺术评测指标维度。
  187. List<ArtQuotaPdf> allSubjectArtQuotaPdfs = new List<ArtQuotaPdf>();
  188. allSubject.ForEach(a =>
  189. {
  190. ArtQuotaPdf artPdf = new ArtQuotaPdf();
  191. List<ArtQuota> parents = ArtService.GetParentByChildId(artSetting.quotas, $"{a.key}");
  192. parents.ForEach(x =>
  193. {
  194. switch (true)
  195. {
  196. case bool when x.level == 1:
  197. artPdf.quota1 = x.id;
  198. artPdf.quotaN1 = x.name;
  199. artPdf.quotaP1 = x.percent;
  200. if (a.key.Equals(x.id))
  201. {
  202. artPdf.quotaName = x.name;
  203. }
  204. break;
  205. case bool when x.level == 2:
  206. artPdf.quota2 = x.id;
  207. artPdf.quotaN2 = x.name;
  208. artPdf.quotaP2 = x.percent;
  209. if (a.key.Equals(x.id))
  210. {
  211. artPdf.quotaName = x.name;
  212. }
  213. break;
  214. case bool when x.level == 3:
  215. artPdf.quota3 = x.id;
  216. artPdf.quotaN3 = x.name;
  217. artPdf.quotaP3 = x.percent;
  218. if (a.key.Equals(x.id))
  219. {
  220. artPdf.quotaName = x.name;
  221. }
  222. break;
  223. }
  224. });
  225. var noneScore = a.list.FindAll(x => x.score == -1);
  226. if (!noneScore.IsNotEmpty())
  227. {
  228. //全部未打分。
  229. if (noneScore.Count >= art.subjects.Count)
  230. {
  231. artPdf.quotaId = a.key;
  232. artPdf.score = 0;
  233. artPdf.scoreData = "-";
  234. artPdf.percent = "0";
  235. }
  236. else
  237. {
  238. //有一部分打分的,只算有分的平均分。
  239. var hasScore = a.list.FindAll(x => x.score >= 0);
  240. if (hasScore.IsNotEmpty())
  241. {
  242. var avgScore = hasScore.Sum(x => x.score) * 1.0 / a.list.Count;
  243. var avg = decimal.Round(decimal.Parse($"{avgScore}"), 2);
  244. artPdf.quotaId = a.key;
  245. artPdf.score = double.Parse($"{avg}");
  246. artPdf.scoreData = $"{avg}";
  247. artPdf.percent = $"{avg}";
  248. }
  249. else
  250. {
  251. artPdf.quotaId = a.key;
  252. artPdf.score = 0;
  253. artPdf.scoreData = "-";
  254. artPdf.percent = "0";
  255. }
  256. }
  257. }
  258. else
  259. {
  260. artPdf.quotaId = a.key;
  261. artPdf.score = 0;
  262. artPdf.scoreData = "-";
  263. artPdf.percent = "0";
  264. }
  265. allSubjectArtQuotaPdfs.Add(artPdf);
  266. });
  267. string level = "";
  268. double allScore = 0;
  269. if (allSubjectArtQuotaPdfs.Any())
  270. {
  271. allScore = allSubjectArtQuotaPdfs.Sum(a => a.score) / allSubjectArtQuotaPdfs.Count;
  272. }
  273. if (allScore >= 100)
  274. {
  275. allScore = 100;
  276. level = "优秀(A+)";
  277. }
  278. if (allScore <= 0)
  279. {
  280. allScore = 0;
  281. level = "待及格(D)";
  282. }
  283. if (allScore < 100)
  284. {
  285. artSetting.reviewLevel.ForEach(r =>
  286. {
  287. if (r.value[0] <= allScore && r.value[1] > allScore)
  288. {
  289. level = r.code;
  290. }
  291. });
  292. }
  293. var rmbs = rmembers.FindAll(r => r.id.Equals(x.studentId) && r.type == 2 && x.code.Equals(x.school));
  294. if (rmbs.IsNotEmpty())
  295. {
  296. x.studentName = rmbs[0].name;
  297. }
  298. List<string> classNames = new List<string>();
  299. HashSet<string> periodIds = new HashSet<string>();
  300. x.classIds.ForEach(c =>
  301. {
  302. var gps = groups.FindAll(g => g.id.Equals(c));
  303. if (gps.IsNotEmpty())
  304. {
  305. classNames.Add(gps[0].name);
  306. if (!string.IsNullOrWhiteSpace(gps[0].periodId))
  307. {
  308. periodIds.Add(gps[0].periodId);
  309. }
  310. }
  311. });
  312. allSubjectArtQuotaPdfs.ForEach(x => x.level = level);
  313. var allSubjectQuotas = allSubjectArtQuotaPdfs.OrderBy(o => o.quota1).ThenBy(o => o.quota2).ThenBy(o => o.quota3);
  314. StringBuilder comment = new StringBuilder();
  315. switch (true)
  316. {
  317. case bool when level.Contains("(A+)"):
  318. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "表现优异"));
  319. break;
  320. case bool when level.Contains("(A)"):
  321. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "表现优秀"));
  322. break;
  323. case bool when level.Contains("(B+)"):
  324. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "表现优良"));
  325. break;
  326. case bool when level.Contains("(B)"):
  327. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "表现良好"));
  328. break;
  329. case bool when level.Contains("(C+)"):
  330. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "还需加强"));
  331. break;
  332. case bool when level.Contains("(C)"):
  333. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "有待提高"));
  334. break;
  335. case bool when level.Contains("(D)"):
  336. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "还需努力"));
  337. break;
  338. }
  339. var score80 = allSubjectArtQuotaPdfs.Where(x => x.score >= 80);
  340. if (score80.Any())
  341. {
  342. List<string> quota = new List<string>();
  343. var quota3s = score80.Where(c => !string.IsNullOrWhiteSpace(c.quota3)).Select(z => z.quotaN3);
  344. if (quota3s.Any())
  345. {
  346. quota.AddRange(quota3s);
  347. }
  348. var quota2s = score80.Where(c => string.IsNullOrWhiteSpace(c.quota3) && !string.IsNullOrWhiteSpace(c.quota2)).Select(z => z.quotaN2);
  349. if (quota2s.Any())
  350. {
  351. quota.AddRange(quota2s);
  352. }
  353. comment.Append(comment2.Replace("{quotasHigh}", string.Join("、", quota)));
  354. }
  355. var score60 = allSubjectArtQuotaPdfs.Where(x => x.score < 60);
  356. if (score60.Any())
  357. {
  358. List<string> quota = new List<string>();
  359. var quota3s = score60.Where(c => !string.IsNullOrWhiteSpace(c.quota3)).Select(z => z.quotaN3);
  360. if (quota3s.Any())
  361. {
  362. quota.AddRange(quota3s);
  363. }
  364. var quota2s = score60.Where(c => string.IsNullOrWhiteSpace(c.quota3) && !string.IsNullOrWhiteSpace(c.quota2)).Select(z => z.quotaN2);
  365. if (quota2s.Any())
  366. {
  367. quota.AddRange(quota2s);
  368. }
  369. comment.Append(comment3.Replace("{quotasLow}", string.Join("、", quota)));
  370. }
  371. string periodId = "";
  372. string periodName = "";
  373. if (periodIds.Any())
  374. {
  375. var ps = school.period.FindAll(x => periodIds.Contains(x.id));
  376. if (ps.Any())
  377. {
  378. periodName = String.Join(",", ps.Select(x => x.name));
  379. periodId = String.Join(",", ps.Select(x => x.id));
  380. }
  381. }
  382. List<ArtSubjectPdf> subjectPdfs = new List<ArtSubjectPdf>();
  383. exams.ForEach(exam => {
  384. var result = examResults.FindAll(e => e.examId.Equals(exam.id));
  385. if (result.Any())
  386. {
  387. var datas = DoKnowledgePoint(result.First(), exam, x.studentId);
  388. if (exam.subjects.Any())
  389. {
  390. ArtSubjectPdf artSubjectPdf = new ArtSubjectPdf()
  391. {
  392. subjectId = exam.subjects.First().id,
  393. subjectName = exam.subjects.First().name
  394. };
  395. datas.pointScores.Value.ForEach(k => {
  396. var artPointPdfs = GetBlockAndDimension(k.score, k.tscore, artSubjectPdf.subjectId, k.name, subjectBindBlocks, artSetting);
  397. artSubjectPdf.pointPdfs.AddRange(artPointPdfs);
  398. });
  399. var pointHigh = artSubjectPdf.pointPdfs.Where(z => z.percent >= 0.8).Select(z => z.point).ToHashSet();
  400. var pointLow = artSubjectPdf.pointPdfs.Where(z => z.percent < 0.6).Select(z => z.point).ToHashSet();
  401. StringBuilder comment = new StringBuilder();
  402. if (pointHigh.Any())
  403. {
  404. comment.Append(comment4.Replace("{pointHigh}", string.Join("、", pointHigh)));
  405. }
  406. if (pointLow.Any())
  407. {
  408. comment.Append(comment5.Replace("{pointLow}", string.Join("、", pointLow)));
  409. }
  410. if (artSubjectPdf.subjectId.Equals("subject_music"))
  411. {
  412. comment.Append(comment_subject_music);
  413. }
  414. if (artSubjectPdf.subjectId.Equals("subject_painting"))
  415. {
  416. comment.Append(comment_subject_painting);
  417. }
  418. artSubjectPdf.comment = comment.ToString();
  419. subjectPdfs.Add(artSubjectPdf);
  420. }
  421. }
  422. });
  423. ArtStudentPdf studentPdf = new ArtStudentPdf
  424. {
  425. artId = art.id,
  426. schoolCode = school.id,
  427. schoolName = school.name,
  428. periodId = periodId,
  429. periodName = periodName,
  430. studentId = x.studentId,
  431. studentName = x.studentName,
  432. picture = x.picture,
  433. classNames = classNames,
  434. artName = art.name,
  435. level = level,
  436. score = allScore,
  437. allSubjectQuotas = allSubjectQuotas.ToList(),
  438. comment = comment.ToString(),
  439. subjectPdfs = subjectPdfs,
  440. };
  441. studentPdfs.Add(studentPdf);
  442. });
  443. // _ = _httpTrigger.RequestHttpTrigger(new { studentPdfs = studentPdfs, artResults, schoolCode = $"{_schoolId}" }, _option.Location, "gen-art-pdf");
  444. var messageBlobPDF = new ServiceBusMessage(new { studentPdfs = studentPdfs, artResults, schoolCode = $"{_schoolId}", bizType = "ArtStudentPdf" }.ToJsonString());
  445. var GenPdfQueue = _configuration.GetValue<string>("Azure:ServiceBus:GenPdfQueue");
  446. await _serviceBus.GetServiceBusClient().SendMessageAsync(GenPdfQueue, messageBlobPDF);
  447. return studentPdfs;
  448. }
  449. private static JsonDocument readFileJson(string path)
  450. {
  451. var sampleJson = System.IO.File.ReadAllBytes(path).AsSpan();
  452. Utf8JsonReader reader = new Utf8JsonReader(sampleJson);
  453. if (JsonDocument.TryParseValue(ref reader, out JsonDocument jsonDoc))
  454. {
  455. return jsonDoc;
  456. }
  457. else
  458. {
  459. return null;
  460. }
  461. }
  462. //获取本次评测所有科目结算结果
  463. /* List<ExamResult> examResults = new();
  464. ExamInfo info = await client.GetContainer(Constant.TEAMModelOS, "Common").ReadItemAsync<ExamInfo>(examId.ToString(), new PartitionKey($"Exam-{code}"));
  465. var query = $"select c.id,c.name,c.subjectId,c.studentScores,c.studentIds,c.paper,c.classes,c.sRate,c.average,c.standard,c.lostStus,c.record,c.phc,c.plc from c where c.examId = '{examId}' and c.subjectId = '{subjectId}' ";
  466. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "Common").GetItemQueryIterator<ExamResult>(queryText: query, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"ExamResult-{examId}") }))
  467. {
  468. examResults.Add(item);
  469. }*/
  470. private static (KeyValuePair<string, List<string>> knowledgeName,
  471. KeyValuePair<string, List<(string name, double score)>> pointScore,
  472. KeyValuePair<string, List<(string name, double score)>> pointTScore,
  473. KeyValuePair<string, List<(string name, double score, double tscore)>> pointScores) DoKnowledgePoint(ExamResult exam, ExamInfo info, string studentId)
  474. {
  475. HashSet<string> knowledge = new();
  476. List<double> point = new();
  477. List<List<double>> result = new();
  478. List<ClassRange> classes = new();
  479. //定位试卷信息
  480. int index = 0;
  481. foreach (ExamSubject subject in info.subjects)
  482. {
  483. if (subject.id.Equals(exam.subjectId))
  484. {
  485. break;
  486. }
  487. else
  488. {
  489. index++;
  490. }
  491. }
  492. if (info.papers[index].knowledge != null && info.papers[index].knowledge.Count > 0)
  493. {
  494. info.papers[index].knowledge.ForEach(k =>
  495. {
  496. k.ForEach(e =>
  497. {
  498. knowledge.Add(e);
  499. });
  500. });
  501. }
  502. else
  503. {
  504. return (default, default, default, default);
  505. }
  506. point = info.papers[index].point;
  507. result = exam.studentScores;
  508. classes = exam.classes;
  509. List<string> knowledgeName = new List<string>();
  510. foreach (string cla in knowledge)
  511. {
  512. knowledgeName.Add(cla);
  513. }
  514. for (int k = 0; k < knowledgeName.Count; k++)
  515. {
  516. if (null == knowledgeName[k])
  517. {
  518. knowledgeName.Remove(knowledgeName[k]);
  519. }
  520. }
  521. List<double> knowScore = new();
  522. //学生得分情况
  523. List<(string name, double score)> pointScore = new();
  524. List<(string name, double score)> pointTScore = new();
  525. List<(string name, double score, double tscore)> pointScores = new();
  526. for (int k = 0; k < knowledgeName.Count; k++)
  527. {
  528. double OnePoint = 0;
  529. List<string> itemNo = new();
  530. int n = 0;
  531. double scores = 0;
  532. info.papers[index].knowledge.ForEach(kno =>
  533. {
  534. if (kno.Contains(knowledgeName[k]))
  535. {
  536. var itemPersent = kno.Count > 0 ? 1 / Convert.ToDouble(kno.Count) : 0;
  537. OnePoint += point[n] * itemPersent;
  538. int stuIndex = exam.studentIds.IndexOf(studentId);
  539. if (exam.studentScores[stuIndex][n] > 0)
  540. {
  541. scores += exam.studentScores[stuIndex][n] * itemPersent;
  542. }
  543. }
  544. n++;
  545. });
  546. //单个知识点的配分
  547. pointScore.Add((knowledgeName[k], OnePoint));
  548. pointTScore.Add((knowledgeName[k], scores));
  549. pointScores.Add((knowledgeName[k], OnePoint, scores));
  550. }
  551. KeyValuePair<string, List<string>> key1 = new(exam.subjectId, knowledgeName);
  552. KeyValuePair<string, List<(string name, double score)>> key2 = new(exam.subjectId, pointScore);
  553. KeyValuePair<string, List<(string name, double score)>> key3 = new(exam.subjectId, pointTScore);
  554. KeyValuePair<string, List<(string name, double score, double tscore)>> key4 = new(exam.subjectId, pointScores);
  555. return (key1, key2, key3, key4);
  556. }
  557. private static List<ArtPointPdf> GetBlockAndDimension(double score, double tscore, string subjectId, string point, List<KeyValuePair<string, List<Block>>> subjectBindBlocks, ArtSetting artSetting)
  558. {
  559. var block = subjectBindBlocks.Find(z => z.Key.Equals(subjectId));
  560. List<ArtPointPdf> artPointPdfs = new List<ArtPointPdf>();
  561. if (!string.IsNullOrWhiteSpace(block.Key))
  562. {
  563. block.Value.ForEach(z => {
  564. if (z.points.Contains(point))
  565. {
  566. var dims = artSetting.dimensions.FindAll(m => m.blocks.Contains(z.name));
  567. if (dims.Any())
  568. {
  569. foreach (var dim in dims)
  570. {
  571. artPointPdfs.Add(
  572. new ArtPointPdf
  573. {
  574. dimension = dim.dimension,
  575. block = z.name,
  576. point = point,
  577. totalScore = score,
  578. score = tscore,
  579. percent = score > 0 ? tscore * 1.0 / score : 0,
  580. }
  581. );
  582. }
  583. }
  584. }
  585. });
  586. }
  587. return artPointPdfs;
  588. }
  589. }
  590. }