ArtService.cs 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606
  1. using Microsoft.Azure.Cosmos;
  2. using Azure.Messaging.ServiceBus;
  3. using Microsoft.Extensions.Configuration;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.IO;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Text.Json;
  10. using System.Threading.Tasks;
  11. using TEAMModelOS.SDK.DI;
  12. using TEAMModelOS.SDK.Extension;
  13. using TEAMModelOS.SDK.Models.Cosmos.Common;
  14. namespace TEAMModelOS.SDK.Models.Service
  15. {
  16. public static class ArtService
  17. {
  18. public static List<ArtQuota> GetParentByChildId(List<ArtQuota> quotas, string childId) {
  19. List<ArtQuota> list_quotas = new List<ArtQuota>();
  20. list_quotas = TreeToList(quotas, list_quotas, null);
  21. List<ArtQuota> parents = new List<ArtQuota>();
  22. parents = GetParents(list_quotas, parents, $"{childId}");
  23. if (parents.IsNotEmpty()) {
  24. int len = parents.Count;
  25. parents.ForEach(x => {
  26. x.level= len-x.level+1;
  27. });
  28. }
  29. return parents;
  30. }
  31. private static List<ArtQuota> GetParents(List<ArtQuota> list, List<ArtQuota> parents, string cid, int level = 1)
  32. {
  33. var child = list.Find(x => x.id.Equals(cid));
  34. if (child != null)
  35. {
  36. child.level = level;
  37. parents.Add(child);
  38. if (!child.pid.Equals(child.id))
  39. {
  40. level++;
  41. return GetParents(list, parents, child.pid, level);
  42. }
  43. else
  44. {
  45. return parents;
  46. }
  47. }
  48. else { return parents; }
  49. }
  50. private static List<ArtQuota> TreeToList(List<ArtQuota> trees, List<ArtQuota> nodes, string pid)
  51. {
  52. List<ArtQuota> list = new List<ArtQuota>();
  53. trees.ForEach(x => {
  54. var node = new ArtQuota
  55. {
  56. pid = string.IsNullOrWhiteSpace(pid) ? x.id : pid,
  57. id = x.id,
  58. name = x.name,
  59. percent = x.percent,
  60. type = x.type,
  61. };
  62. list.Add(node);
  63. });
  64. nodes.AddRange(list);
  65. foreach (ArtQuota tree in trees)
  66. {
  67. if (tree.children.IsNotEmpty())
  68. {
  69. TreeToList(tree.children, nodes, tree.id);
  70. }
  71. }
  72. return nodes;
  73. }
  74. public async static Task GenArtPDF (List<string> studentIds, string _artId, string _schoolId, string head_lang,AzureServiceBusFactory _serviceBus, IConfiguration _configuration)
  75. {
  76. var messageBlobPDF = new ServiceBusMessage(new { studentIds, artId= _artId, schoolCode = $"{_schoolId}", headLang= head_lang, bizType = "ArtStudentPdf" }.ToJsonString());
  77. var GenPdfQueue = _configuration.GetValue<string>("Azure:ServiceBus:GenPdfQueue");
  78. await _serviceBus.GetServiceBusClient().SendMessageAsync(GenPdfQueue, messageBlobPDF);
  79. }
  80. public async static Task<(List<ArtStudentPdf> studentPdfs, List<StudentArtResult> artResults)> GenStuArtPDF(List<string> studentIds, string _artId,string _schoolId,string head_lang ,AzureCosmosFactory _azureCosmos,
  81. CoreAPIHttpService _coreAPIHttpService, DingDing _dingDing) {
  82. var client = _azureCosmos.GetCosmosClient();
  83. string query = $" select value c from c where c.school = '{_schoolId}' ";
  84. if (studentIds.Any())
  85. {
  86. query = $" select value c from c where c.school = '{_schoolId}' and c.studentId in ({string.Join(",", studentIds.Select(z => $"'{z}'"))})";
  87. }
  88. List<StudentArtResult> artResults = new List<StudentArtResult>();
  89. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, Constant.Student).GetItemQueryIteratorSql<StudentArtResult>
  90. (queryText: query, requestOptions: new QueryRequestOptions { PartitionKey = new PartitionKey($"ArtResult-{_artId}") }))
  91. {
  92. artResults.Add(item);
  93. }
  94. School school = await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, Constant.School).ReadItemAsync<School>($"{_schoolId}", new PartitionKey("Base"));
  95. string path = Path.Combine("", $"Lang/{head_lang}.json");
  96. string comment1 = "";
  97. string comment2 = "";
  98. string comment3 = "";
  99. string comment4 = "";
  100. string comment5 = "";
  101. string comment_subject_music = "";
  102. string comment_subject_painting = "";
  103. var jsonDoc = readFileJson(path);
  104. if (jsonDoc != null)
  105. {
  106. if (jsonDoc.RootElement.TryGetProperty("art-template-comment1", out JsonElement _c1))
  107. {
  108. comment1 = $"{_c1}";
  109. }
  110. if (jsonDoc.RootElement.TryGetProperty("art-template-comment2", out JsonElement _c2))
  111. {
  112. comment2 = $"{_c2}";
  113. }
  114. if (jsonDoc.RootElement.TryGetProperty("art-template-comment3", out JsonElement _c3))
  115. {
  116. comment3 = $"{_c3}";
  117. }
  118. if (jsonDoc.RootElement.TryGetProperty("art-template-comment4", out JsonElement _c4))
  119. {
  120. comment4 = $"{_c4}";
  121. }
  122. if (jsonDoc.RootElement.TryGetProperty("art-template-comment5", out JsonElement _c5))
  123. {
  124. comment5 = $"{_c5}";
  125. }
  126. if (jsonDoc.RootElement.TryGetProperty("art-template-subject_music", out JsonElement _subject_music))
  127. {
  128. comment_subject_music = $"{_subject_music}";
  129. }
  130. if (jsonDoc.RootElement.TryGetProperty("art-template-subject_painting", out JsonElement _subject_painting))
  131. {
  132. comment_subject_painting = $"{_subject_painting}";
  133. }
  134. }
  135. ArtEvaluation art = await client.GetContainer(Constant.TEAMModelOS, "Common").ReadItemAsync<ArtEvaluation>($"{_artId}", new PartitionKey($"Art-{_schoolId}"));
  136. ArtSetting artSetting = await client.GetContainer(Constant.TEAMModelOS, Constant.Normal).ReadItemAsync<ArtSetting>($"{school.areaId}", new PartitionKey($"ArtSetting"));
  137. var allExamIds = art.settings.SelectMany(x => x.task).Where(z => z.type == 1);
  138. var subjects = art.subjects;
  139. //获取学校的所有艺术科目的uuid,并映射找到相应的知识点,知识块。
  140. var schoolSubjects = school.period.SelectMany(x => x.subjects).Where(s => !string.IsNullOrWhiteSpace(s.bindId) && subjects.Select(z => z.id).Contains(s.bindId));
  141. StringBuilder sql = new StringBuilder($"select value(c) from c");
  142. List<KeyValuePair<string, List<Block>>> subjectBindBlocks = new List<KeyValuePair<string, List<Block>>>();
  143. foreach (var schSub in schoolSubjects)
  144. {
  145. List<Block> blocks = new List<Block>();
  146. string code = $"Knowledge-{_schoolId}-{schSub.id}";
  147. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School")
  148. .GetItemQueryIteratorSql<Knowledge>(queryText: sql.ToString(), requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"{code}") }))
  149. {
  150. item.blocks.ForEach(x =>
  151. {
  152. var block = blocks.Find(z => z.name.Equals(x.name));
  153. if (block != null)
  154. {
  155. block.points.AddRange(x.points);
  156. }
  157. else
  158. {
  159. blocks.Add(x);
  160. }
  161. });
  162. }
  163. subjectBindBlocks.Add(new KeyValuePair<string, List<Block>>(schSub.bindId, blocks));
  164. }
  165. List<ExamInfo> exams = new List<ExamInfo>();
  166. List<ExamResult> examResults = new();
  167. if (allExamIds.Any())
  168. {
  169. var queryExam = $"select value c from c where c.id in ({string.Join(",", allExamIds.Select(x => $"'{x.acId}'"))}) ";
  170. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "Common").GetItemQueryIteratorSql<ExamInfo>(queryText: queryExam, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Exam-{_schoolId}") }))
  171. {
  172. exams.Add(item);
  173. }
  174. foreach (var allexamId in allExamIds)
  175. {
  176. 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}' ";
  177. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "Common").GetItemQueryIteratorSql<ExamResult>(queryText: queryResult, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"ExamResult-{allexamId.acId}") }))
  178. {
  179. examResults.Add(item);
  180. }
  181. }
  182. }
  183. (List<RMember> rmembers, List<RGroupList> groups) = await GroupListService.GetMemberByListids(_coreAPIHttpService, client, _dingDing, art.classes, art.school);
  184. List<ArtStudentPdf> studentPdfs = new List<ArtStudentPdf>();
  185. artResults.ForEach(x =>
  186. {
  187. var allSubject = x.results.GroupBy(g => g.quotaId).Select(s => new { key = s.Key, list = s.ToList() }).ToList();
  188. var groupSubject = x.results.GroupBy(g => $"{g.quotaId}-{g.subjectId}").Select(s => new { key = s.Key, list = s.ToList() }).ToList();
  189. //综合-所有科目的艺术评测指标维度。
  190. List<ArtQuotaPdf> allSubjectArtQuotaPdfs = new List<ArtQuotaPdf>();
  191. allSubject.ForEach(a =>
  192. {
  193. ArtQuotaPdf artPdf = new ArtQuotaPdf();
  194. List<ArtQuota> parents = ArtService.GetParentByChildId(artSetting.quotas, $"{a.key}");
  195. parents.ForEach(x =>
  196. {
  197. switch (true)
  198. {
  199. case bool when x.level == 1:
  200. artPdf.quota1 = x.id;
  201. artPdf.quotaN1 = x.name;
  202. artPdf.quotaP1 = x.percent;
  203. if (a.key.Equals(x.id))
  204. {
  205. artPdf.quotaName = x.name;
  206. }
  207. break;
  208. case bool when x.level == 2:
  209. artPdf.quota2 = x.id;
  210. artPdf.quotaN2 = x.name;
  211. artPdf.quotaP2 = x.percent;
  212. if (a.key.Equals(x.id))
  213. {
  214. artPdf.quotaName = x.name;
  215. }
  216. break;
  217. case bool when x.level == 3:
  218. artPdf.quota3 = x.id;
  219. artPdf.quotaN3 = x.name;
  220. artPdf.quotaP3 = x.percent;
  221. if (a.key.Equals(x.id))
  222. {
  223. artPdf.quotaName = x.name;
  224. }
  225. break;
  226. }
  227. });
  228. var noneScore = a.list.FindAll(x => x.score == -1);
  229. if (!noneScore.IsNotEmpty())
  230. {
  231. //全部未打分。
  232. if (noneScore.Count >= art.subjects.Count)
  233. {
  234. artPdf.quotaId = a.key;
  235. artPdf.score = 0;
  236. artPdf.scoreData = "-";
  237. artPdf.percent = "0";
  238. }
  239. else
  240. {
  241. //有一部分打分的,只算有分的平均分。
  242. var hasScore = a.list.FindAll(x => x.score >= 0);
  243. if (hasScore.IsNotEmpty())
  244. {
  245. var avgScore = hasScore.Sum(x => x.score) * 1.0 / a.list.Count;
  246. var avg = decimal.Round(decimal.Parse($"{avgScore}"), 2);
  247. artPdf.quotaId = a.key;
  248. artPdf.score = double.Parse($"{avg}");
  249. artPdf.scoreData = $"{avg}";
  250. artPdf.percent = $"{avg}";
  251. }
  252. else
  253. {
  254. artPdf.quotaId = a.key;
  255. artPdf.score = 0;
  256. artPdf.scoreData = "-";
  257. artPdf.percent = "0";
  258. }
  259. }
  260. }
  261. else
  262. {
  263. artPdf.quotaId = a.key;
  264. artPdf.score = 0;
  265. artPdf.scoreData = "-";
  266. artPdf.percent = "0";
  267. }
  268. allSubjectArtQuotaPdfs.Add(artPdf);
  269. });
  270. string level = "";
  271. double allScore = 0;
  272. if (allSubjectArtQuotaPdfs.Any())
  273. {
  274. allScore = allSubjectArtQuotaPdfs.Sum(a => a.score) / allSubjectArtQuotaPdfs.Count;
  275. }
  276. if (allScore >= 100)
  277. {
  278. allScore = 100;
  279. level = "优秀(A+)";
  280. }
  281. if (allScore <= 0)
  282. {
  283. allScore = 0;
  284. level = "待及格(D)";
  285. }
  286. if (allScore < 100)
  287. {
  288. artSetting.reviewLevel.ForEach(r =>
  289. {
  290. if (r.value[0] <= allScore && r.value[1] > allScore)
  291. {
  292. level = r.code;
  293. }
  294. });
  295. }
  296. var rmbs = rmembers.FindAll(r => r.id.Equals(x.studentId) && r.type == 2 && x.code.Equals(x.school));
  297. if (rmbs.IsNotEmpty())
  298. {
  299. x.studentName = rmbs[0].name;
  300. }
  301. List<string> classNames = new List<string>();
  302. HashSet<string> periodIds = new HashSet<string>();
  303. x.classIds.ForEach(c =>
  304. {
  305. var gps = groups.FindAll(g => g.id.Equals(c));
  306. if (gps.IsNotEmpty())
  307. {
  308. classNames.Add(gps[0].name);
  309. if (!string.IsNullOrWhiteSpace(gps[0].periodId))
  310. {
  311. periodIds.Add(gps[0].periodId);
  312. }
  313. }
  314. });
  315. allSubjectArtQuotaPdfs.ForEach(x => x.level = level);
  316. var allSubjectQuotas = allSubjectArtQuotaPdfs.OrderBy(o => o.quota1).ThenBy(o => o.quota2).ThenBy(o => o.quota3);
  317. StringBuilder comment = new StringBuilder();
  318. switch (true)
  319. {
  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("(A)"):
  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("(B)"):
  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("(C)"):
  336. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "有待提高"));
  337. break;
  338. case bool when level.Contains("(D)"):
  339. comment.Append(comment1.Replace("{studentName}", x.studentName).Replace("{level}", "还需努力"));
  340. break;
  341. }
  342. var score80 = allSubjectArtQuotaPdfs.Where(x => x.score >= 80);
  343. if (score80.Any())
  344. {
  345. List<string> quota = new List<string>();
  346. var quota3s = score80.Where(c => !string.IsNullOrWhiteSpace(c.quota3)).Select(z => z.quotaN3);
  347. if (quota3s.Any())
  348. {
  349. quota.AddRange(quota3s);
  350. }
  351. var quota2s = score80.Where(c => string.IsNullOrWhiteSpace(c.quota3) && !string.IsNullOrWhiteSpace(c.quota2)).Select(z => z.quotaN2);
  352. if (quota2s.Any())
  353. {
  354. quota.AddRange(quota2s);
  355. }
  356. comment.Append(comment2.Replace("{quotasHigh}", string.Join("、", quota)));
  357. }
  358. var score60 = allSubjectArtQuotaPdfs.Where(x => x.score < 60);
  359. if (score60.Any())
  360. {
  361. List<string> quota = new List<string>();
  362. var quota3s = score60.Where(c => !string.IsNullOrWhiteSpace(c.quota3)).Select(z => z.quotaN3);
  363. if (quota3s.Any())
  364. {
  365. quota.AddRange(quota3s);
  366. }
  367. var quota2s = score60.Where(c => string.IsNullOrWhiteSpace(c.quota3) && !string.IsNullOrWhiteSpace(c.quota2)).Select(z => z.quotaN2);
  368. if (quota2s.Any())
  369. {
  370. quota.AddRange(quota2s);
  371. }
  372. comment.Append(comment3.Replace("{quotasLow}", string.Join("、", quota)));
  373. }
  374. string periodId = "";
  375. string periodName = "";
  376. if (periodIds.Any())
  377. {
  378. var ps = school.period.FindAll(x => periodIds.Contains(x.id));
  379. if (ps.Any())
  380. {
  381. periodName = String.Join(",", ps.Select(x => x.name));
  382. periodId = String.Join(",", ps.Select(x => x.id));
  383. }
  384. }
  385. List<ArtSubjectPdf> subjectPdfs = new List<ArtSubjectPdf>();
  386. exams.ForEach(exam => {
  387. var result = examResults.FindAll(e => e.examId.Equals(exam.id));
  388. if (result.Any())
  389. {
  390. var datas = DoKnowledgePoint(result.First(), exam, x.studentId);
  391. if (exam.subjects.Any())
  392. {
  393. ArtSubjectPdf artSubjectPdf = new ArtSubjectPdf()
  394. {
  395. subjectId = exam.subjects.First().id,
  396. subjectName = exam.subjects.First().name
  397. };
  398. datas.pointScores.Value.ForEach(k => {
  399. var artPointPdfs = GetBlockAndDimension(k.score, k.tscore, artSubjectPdf.subjectId, k.name, subjectBindBlocks, artSetting);
  400. artSubjectPdf.pointPdfs.AddRange(artPointPdfs);
  401. });
  402. var pointHigh = artSubjectPdf.pointPdfs.Where(z => z.percent >= 0.8).Select(z => z.point).ToHashSet();
  403. var pointLow = artSubjectPdf.pointPdfs.Where(z => z.percent < 0.6).Select(z => z.point).ToHashSet();
  404. StringBuilder comment = new StringBuilder();
  405. if (pointHigh.Any())
  406. {
  407. comment.Append(comment4.Replace("{pointHigh}", string.Join("、", pointHigh)));
  408. }
  409. if (pointLow.Any())
  410. {
  411. comment.Append(comment5.Replace("{pointLow}", string.Join("、", pointLow)));
  412. }
  413. if (artSubjectPdf.subjectId.Equals("subject_music"))
  414. {
  415. comment.Append(comment_subject_music);
  416. }
  417. if (artSubjectPdf.subjectId.Equals("subject_painting"))
  418. {
  419. comment.Append(comment_subject_painting);
  420. }
  421. artSubjectPdf.comment = comment.ToString();
  422. subjectPdfs.Add(artSubjectPdf);
  423. }
  424. }
  425. });
  426. ArtStudentPdf studentPdf = new ArtStudentPdf
  427. {
  428. artId = art.id,
  429. schoolCode = school.id,
  430. schoolName = school.name,
  431. periodId = periodId,
  432. periodName = periodName,
  433. studentId = x.studentId,
  434. studentName = x.studentName,
  435. picture = x.picture,
  436. classNames = classNames,
  437. artName = art.name,
  438. level = level,
  439. score = allScore,
  440. allSubjectQuotas = allSubjectQuotas.ToList(),
  441. comment = comment.ToString(),
  442. subjectPdfs = subjectPdfs,
  443. };
  444. studentPdfs.Add(studentPdf);
  445. });
  446. // _ = _httpTrigger.RequestHttpTrigger(new { studentPdfs = studentPdfs, artResults, schoolCode = $"{_schoolId}" }, _option.Location, "gen-art-pdf");
  447. return (studentPdfs, artResults);
  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").GetItemQueryIteratorSql<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. }