Form1.cs 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. using WordAnalyze;
  11. using Logger = Log.Log;
  12. namespace WindowsFormsApp1
  13. {
  14. public partial class Form1 : Form
  15. {
  16. private WordAnalyze.Analyze Analyzer = null;
  17. public Form1()
  18. {
  19. InitializeComponent();
  20. Logger.Init("log.log");
  21. init_listView();
  22. init_textBox();
  23. }
  24. // 初始化显示的列表
  25. private void init_listView()
  26. {
  27. listView1.View = View.Details;
  28. Console.WriteLine(listView1.Columns.Count);
  29. // 第一列,文件名
  30. if (0 == listView1.Columns.Count)
  31. {
  32. listView1.Columns.Add("文件名");
  33. Console.WriteLine(listView1.Columns.Count);
  34. }
  35. Console.WriteLine(listView1.Columns.Count);
  36. listView1.Columns[0].Text = "文件名";
  37. listView1.Columns[0].Width = 200;
  38. listView1.Columns[0].TextAlign = HorizontalAlignment.Left;
  39. // 第二列,状态
  40. if (1 == listView1.Columns.Count)
  41. {
  42. listView1.Columns.Add("状态");
  43. }
  44. listView1.Columns[1].Text = "状态";
  45. listView1.Columns[1].Width = 50;
  46. listView1.Columns[1].TextAlign = HorizontalAlignment.Left;
  47. // 第三列,错误信息,成功则忽略
  48. if (2 == listView1.Columns.Count)
  49. {
  50. listView1.Columns.Add("信息");
  51. }
  52. listView1.Columns[2].Text = "信息";
  53. listView1.Columns[2].Width = 300;
  54. listView1.Columns[2].TextAlign = HorizontalAlignment.Left;
  55. }
  56. // 初始化存储文件夹的显示框
  57. private void init_textBox()
  58. {
  59. textBox1.Enabled = false;
  60. }
  61. // 开始处理word文档
  62. private void button1_Click(object sender, EventArgs e)
  63. {
  64. if (fileNames == null || fileNames.Length < 1)
  65. {
  66. Logger.D("event start, but no file to analyse");
  67. return;
  68. }
  69. try
  70. {
  71. // 初始化处理文档对象
  72. Analyzer = new WordAnalyze.Analyze();
  73. } catch (System.Exception err)
  74. {
  75. Logger.E("analyze new word analyze object error happened: {0}", err.Message.ToString());
  76. return;
  77. }
  78. button1.Enabled = false;
  79. listview_draw(fileNames);
  80. for (int i = 0; i < fileNames.Length; i ++)
  81. {
  82. execStatus(i);
  83. Logger.D("startanalyze with filename({0})", fileNames[i]);
  84. if (listView1.Items.Count < i + 1)
  85. {
  86. Logger.D("analyze with filename({0}) success but item with index({1}) is unexpected", fileNames[i], i);
  87. continue;
  88. }
  89. if (listView1.Items[i].SubItems.Count != 3)
  90. {
  91. Logger.D("analyze with filename({0}) success but item with index({1}) contain unexpected subitem length({2})", fileNames[i], i, listView1.Items[i].SubItems.Count);
  92. continue;
  93. }
  94. var result = Analyzer.AnalyzeFile(fileNames[i]);
  95. string status = "成功";
  96. if (result != "")
  97. {
  98. status = "失败";
  99. }
  100. listView1.Items[i].SubItems[1].Text = status;
  101. listView1.Items[i].SubItems[2].Text = result;
  102. Logger.D("analyze with filename({0}) success with result({1})", fileNames[i], result);
  103. }
  104. try
  105. {
  106. Analyzer.Close();
  107. }catch(System.Exception err)
  108. {
  109. Logger.E("analyze quit but error happened: {0}", err.Message.ToString());
  110. }
  111. button1.Enabled = true;
  112. }
  113. private void folderBrowserDialog1_HelpRequest(object sender, EventArgs e)
  114. {
  115. }
  116. private void openFileDialog1_FileOk(object sender, CancelEventArgs e)
  117. {
  118. }
  119. private void button2_Click(object sender, EventArgs e)
  120. {
  121. // 选择文件
  122. OpenFileDialog openFileDialog = new OpenFileDialog();
  123. openFileDialog.Filter = "doc files (*.doc)|*.doc| docx files (*.docx)|*.docx";
  124. openFileDialog.Multiselect = true;
  125. openFileDialog.Title = "选择doc或者docx文件";
  126. if (openFileDialog.ShowDialog() == DialogResult.OK)
  127. {
  128. fileNames = openFileDialog.FileNames;
  129. // 先清空列表,再渲染列表
  130. listview_draw(fileNames);
  131. }
  132. }
  133. private void Form1_Load(object sender, EventArgs e)
  134. {
  135. }
  136. private void listview_draw(string[] fileNames)
  137. {
  138. listView1.Items.Clear();
  139. for (int i = 0; i < fileNames.Length; i++)
  140. {
  141. ListViewItem item = new ListViewItem();
  142. item.Text = fileNames[i];
  143. item.SubItems.Add("等待中");
  144. item.SubItems.Add("");
  145. listView1.Items.Add(item);
  146. }
  147. }
  148. private void execStatus(int index)
  149. {
  150. var item = listView1.Items[index];
  151. item.SubItems[1].Text = "执行中";
  152. }
  153. private void listView1_SelectedIndexChanged(object sender, EventArgs e)
  154. {
  155. }
  156. private void button3_Click(object sender, EventArgs e)
  157. {
  158. FolderBrowserDialog folderBrowserDialog = new FolderBrowserDialog();
  159. if(folderBrowserDialog.ShowDialog() == DialogResult.OK)
  160. {
  161. AimFolder = folderBrowserDialog.SelectedPath;
  162. textBox1.Text = AimFolder;
  163. Analyzer.SetPath(AimFolder);
  164. }
  165. }
  166. private void textBox1_TextChanged(object sender, EventArgs e)
  167. {
  168. }
  169. }
  170. }