lab 2 in process
This commit is contained in:
parent
e6dd043cbb
commit
19b9d83d74
@ -1,4 +1,5 @@
|
||||
using DocumentFormat.OpenXml;
|
||||
using ComponentsLibrary.entities;
|
||||
using DocumentFormat.OpenXml;
|
||||
using DocumentFormat.OpenXml.Packaging;
|
||||
using DocumentFormat.OpenXml.Wordprocessing;
|
||||
using System.ComponentModel;
|
||||
@ -16,37 +17,71 @@ namespace ComponentsLibrary
|
||||
public ComponentBigText(IContainer container)
|
||||
{
|
||||
container.Add(this);
|
||||
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
//публичный метод
|
||||
public void SetText(string fileUrl, string fileName, string[] text)
|
||||
public void CreateWordText(DocumentSymple docInfo)
|
||||
{
|
||||
if (string.IsNullOrEmpty(fileUrl) || string.IsNullOrEmpty(fileName))
|
||||
if (string.IsNullOrEmpty(docInfo.FileUrl) || string.IsNullOrEmpty(docInfo.Title) || !CheckData(docInfo.Text))
|
||||
{
|
||||
throw new ArgumentException("File URL or filename cannot be empty.");
|
||||
throw new Exception("Не все данные заполнены");
|
||||
}
|
||||
|
||||
using (WordprocessingDocument wordDocument = WordprocessingDocument.Create(Path.Combine(fileUrl, fileName), WordprocessingDocumentType.Document))
|
||||
using (WordprocessingDocument wordDocument = WordprocessingDocument.Create(docInfo.FileUrl, WordprocessingDocumentType.Document))
|
||||
{
|
||||
|
||||
// Добавляем главную часть документа
|
||||
MainDocumentPart mainPart = wordDocument.AddMainDocumentPart();
|
||||
mainPart.Document = new Document();
|
||||
Body body = new Body();
|
||||
Body body = mainPart.Document.AppendChild(new Body());
|
||||
|
||||
// Создаем параграф для заголовка
|
||||
Paragraph titleParagraph = new Paragraph();
|
||||
|
||||
// Задаем свойства параграфа (центровка и отступ)
|
||||
ParagraphProperties paragraphProperties = new ParagraphProperties();
|
||||
paragraphProperties.AppendChild(new Justification() { Val = JustificationValues.Center });
|
||||
|
||||
// Применяем свойства параграфа к заголовку
|
||||
titleParagraph.AppendChild(paragraphProperties);
|
||||
|
||||
// Создаем "бегунок" текста
|
||||
Run titleRun = new Run();
|
||||
|
||||
// Устанавливаем свойства "бегунка" (шрифт, размер, жирный шрифт)
|
||||
RunProperties runProperties = new RunProperties();
|
||||
runProperties.AppendChild(new Bold());
|
||||
runProperties.AppendChild(new FontSize() { Val = "48" }); // Размер шрифта, 24pt
|
||||
|
||||
// Применяем свойства к тексту
|
||||
titleRun.AppendChild(runProperties);
|
||||
|
||||
// Добавляем текст заголовка
|
||||
titleRun.AppendChild(new Text(docInfo.Title));
|
||||
|
||||
// Добавляем "бегунок" с текстом в параграф
|
||||
titleParagraph.AppendChild(titleRun);
|
||||
|
||||
// Добавляем параграф в тело документа
|
||||
body.AppendChild(titleParagraph);
|
||||
|
||||
|
||||
foreach (var line in text)
|
||||
foreach (var line in docInfo.Text)
|
||||
{
|
||||
Paragraph paragraph = new Paragraph(new Run(new Text(line)));
|
||||
body.Append(paragraph);
|
||||
}
|
||||
|
||||
|
||||
mainPart.Document.Append(body);
|
||||
mainPart.Document.Save();
|
||||
}
|
||||
}
|
||||
|
||||
bool CheckData(string[] data)
|
||||
{
|
||||
for (int i = 0; i < data.Length; i++)
|
||||
{
|
||||
if (string.IsNullOrEmpty(data[i])) return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,5 +1,6 @@
|
||||
using DocumentFormat.OpenXml.Packaging;
|
||||
using DocumentFormat.OpenXml.Wordprocessing;
|
||||
using Aspose.Words;
|
||||
using Aspose.Words.Tables;
|
||||
using ComponentsLibrary.entities;
|
||||
using System.ComponentModel;
|
||||
|
||||
|
||||
@ -18,94 +19,126 @@ namespace ComponentsLibrary
|
||||
|
||||
InitializeComponent();
|
||||
}
|
||||
/*
|
||||
public void CreateDocument(string filePath, DocumentTable<T> documentTable)
|
||||
public void CreateTable<T>(DocumentTable<T> tableWord) where T : class
|
||||
{
|
||||
ValidateInput(documentTable);
|
||||
|
||||
using (WordprocessingDocument wordDocument = WordprocessingDocument.Create(filePath, DocumentFormat.OpenXml.WordprocessingDocumentType.Document))
|
||||
// Проверка наличия данных и определений столбцов
|
||||
if (tableWord.Items == null || tableWord.Items.Count == 0 || tableWord.ColumnParameters == null || tableWord.ColumnParameters.Count == 0)
|
||||
{
|
||||
MainDocumentPart mainPart = wordDocument.AddMainDocumentPart();
|
||||
mainPart.Document = new Document();
|
||||
Body body = new Body();
|
||||
throw new ArgumentException("Не все данные заполнены");
|
||||
}
|
||||
|
||||
// Добавление заголовка
|
||||
Paragraph titleParagraph = new Paragraph(new Run(new Text(documentTable.DocumentTitle)));
|
||||
body.Append(titleParagraph);
|
||||
// Проверка, что все ячейки шапки заполнены и для каждого столбца определено свойство/поле класса
|
||||
foreach (var columnParameters in tableWord.ColumnParameters)
|
||||
{
|
||||
if (string.IsNullOrEmpty(columnParameters.PropertyName))
|
||||
{
|
||||
throw new ArgumentException($"Incomplete column definition: {columnParameters.FirstRowHeader}");
|
||||
}
|
||||
}
|
||||
|
||||
// Создание документа
|
||||
Document document = new Document();
|
||||
DocumentBuilder builder = new DocumentBuilder(document);
|
||||
|
||||
// Установка стиля заголовка
|
||||
Style titleStyle = builder.Document.Styles.Add(StyleType.Paragraph, "Title");
|
||||
titleStyle.Font.Size = 16;
|
||||
titleStyle.Font.Bold = true;
|
||||
|
||||
// Установка заголовка документа
|
||||
builder.ParagraphFormat.Style = titleStyle;
|
||||
builder.Writeln(tableWord.Title);
|
||||
|
||||
// Создание таблицы
|
||||
Table table = new Table();
|
||||
CreateHeaderRows(documentTable, table);
|
||||
FillTableData(documentTable, table);
|
||||
Table table = builder.StartTable();
|
||||
|
||||
body.Append(table);
|
||||
mainPart.Document.Append(body);
|
||||
mainPart.Document.Save();
|
||||
// Установка стиля для шапки таблицы
|
||||
Style headerStyle = builder.Document.Styles.Add(StyleType.Paragraph, "HeaderStyle");
|
||||
headerStyle.Font.Size = 14;
|
||||
headerStyle.Font.Bold = true;
|
||||
|
||||
|
||||
// Создание первой строки (шапка)
|
||||
foreach (var columnParameters in tableWord.ColumnParameters)
|
||||
{
|
||||
builder.InsertCell();
|
||||
builder.ParagraphFormat.Style = headerStyle;
|
||||
builder.CellFormat.PreferredWidth = PreferredWidth.FromPoints(columnParameters.Width);
|
||||
builder.Write(columnParameters.FirstRowHeader);
|
||||
}
|
||||
builder.EndRow();
|
||||
|
||||
// Создание второй строки (шапка)
|
||||
foreach (var columnParameters in tableWord.ColumnParameters)
|
||||
{
|
||||
builder.InsertCell();
|
||||
builder.ParagraphFormat.Style = headerStyle;
|
||||
builder.CellFormat.PreferredWidth = PreferredWidth.FromPoints(columnParameters.Width);
|
||||
builder.Write(columnParameters.SecondRowHeader);
|
||||
}
|
||||
builder.EndRow();
|
||||
|
||||
int startCellIndex = -1;
|
||||
int endCellIndex = -1;
|
||||
|
||||
// Создаем набор для хранения индексов ячеек, которые уже объединены по горизонтали
|
||||
HashSet<int> horizontallyMergedCells = new();
|
||||
// Объединение ячеек в первой строке шапки таблицы (если необходимо)
|
||||
foreach (var mergedColumn in tableWord.MergedColumns)
|
||||
{
|
||||
startCellIndex = mergedColumn[0];
|
||||
endCellIndex = mergedColumn[^1];
|
||||
|
||||
for (int i = startCellIndex; i <= endCellIndex; i++)
|
||||
{
|
||||
// Устанавливаем горизонтальное объединение
|
||||
table.Rows[0].Cells[i].CellFormat.HorizontalMerge = i == startCellIndex ? CellMerge.First : CellMerge.Previous;
|
||||
horizontallyMergedCells.Add(i); // Сохраняем индекс ячейки, которая объединена по горизонтали
|
||||
|
||||
// Устанавливаем выравнивание по центру
|
||||
if (i == startCellIndex)
|
||||
{
|
||||
// Центрируем текст внутри ячейки
|
||||
table.Rows[0].Cells[i].Paragraphs[0].ParagraphFormat.Alignment = ParagraphAlignment.Center;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void ValidateInput(DocumentTable<T> documentTable)
|
||||
// Установка вертикального объединения заголовков
|
||||
for (int columnIndex = 0; columnIndex < tableWord.ColumnParameters.Count; columnIndex++)
|
||||
{
|
||||
// Проводим проверки на заполненность и соответствие
|
||||
if (string.IsNullOrEmpty(documentTable.DocumentTitle))
|
||||
throw new ArgumentException("Заголовок документа не может быть пустым.");
|
||||
// Пропускаем столбцы, которые уже объединены по горизонтали
|
||||
if (horizontallyMergedCells.Contains(columnIndex))
|
||||
continue;
|
||||
|
||||
if (documentTable.Headers == null || documentTable.Headers.Count == 0 || documentTable.PropertyMappings == null || documentTable.PropertyMappings.Count == 0)
|
||||
throw new ArgumentException("Заголовки и отображения свойств должны быть заполнены.");
|
||||
|
||||
if (documentTable.Data == null || !documentTable.Data.Any())
|
||||
throw new ArgumentException("Данные таблицы не могут быть пустыми.");
|
||||
|
||||
// Проверка на некорректные столбцы объединения
|
||||
foreach (var column in documentTable.MergedColumns)
|
||||
{
|
||||
if (column < 0 || column >= documentTable.Headers.Count)
|
||||
throw new ArgumentOutOfRangeException($"Неверный номер объединяемого столбца: {column}");
|
||||
table.Rows[0].Cells[columnIndex].CellFormat.VerticalMerge = CellMerge.First;
|
||||
table.Rows[1].Cells[columnIndex].CellFormat.VerticalMerge = CellMerge.Previous;
|
||||
}
|
||||
|
||||
// Проверка, что все заголовки заполнены
|
||||
foreach (var header in documentTable.Headers)
|
||||
// Установка стиля для данных таблицы
|
||||
Style dataStyle = builder.Document.Styles.Add(StyleType.Paragraph, "DataStyle");
|
||||
dataStyle.Font.Size = 12;
|
||||
dataStyle.Font.Bold = false;
|
||||
|
||||
// Вставка данных в таблицу
|
||||
foreach (var item in tableWord.Items)
|
||||
{
|
||||
if (string.IsNullOrEmpty(header))
|
||||
throw new ArgumentException("Все заголовки должны быть заполнены.");
|
||||
foreach (var сolumnParameters in tableWord.ColumnParameters)
|
||||
{
|
||||
builder.InsertCell();
|
||||
builder.ParagraphFormat.Style = dataStyle;
|
||||
// Получение значения свойства/поля объекта по заданному имени
|
||||
var propertyValue = item.GetType().GetProperty(сolumnParameters.PropertyName)?.GetValue(item)?.ToString();
|
||||
builder.Write(propertyValue ?? string.Empty);
|
||||
}
|
||||
builder.EndRow();
|
||||
}
|
||||
|
||||
private void CreateHeaderRows(DocumentTable<T> documentTable, Table table)
|
||||
{
|
||||
// Создаем две строки заголовков
|
||||
for (int rowIndex = 0; rowIndex < 2; rowIndex++)
|
||||
{
|
||||
TableRow headerRow = new TableRow();
|
||||
for (int colIndex = 0; colIndex < documentTable.Headers.Count; colIndex++)
|
||||
{
|
||||
TableCell cell = new TableCell(new Paragraph(new Run(new Text(documentTable.Headers[colIndex]))));
|
||||
if (!documentTable.MergedColumns.Contains(colIndex))
|
||||
{
|
||||
// Объединяем ячейку по строкам
|
||||
cell.VerticalMerge = new TableCellVerticalMerge();
|
||||
builder.EndTable();
|
||||
|
||||
// Сохранение документа в файл
|
||||
document.Save(tableWord.FileUrl);
|
||||
}
|
||||
|
||||
headerRow.Append(cell);
|
||||
}
|
||||
table.Append(headerRow);
|
||||
}
|
||||
}
|
||||
|
||||
private void FillTableData(DocumentTable<T> documentTable, Table table)
|
||||
{
|
||||
// Заполнение данных таблицы
|
||||
foreach (var item in documentTable.Data)
|
||||
{
|
||||
TableRow dataRow = new TableRow();
|
||||
for (int colIndex = 0; colIndex < documentTable.PropertyMappings.Count; colIndex++)
|
||||
{
|
||||
var propertyValue = typeof(T).GetProperty(documentTable.PropertyMappings[colIndex])?.GetValue(item, null);
|
||||
TableCell cell = new TableCell(new Paragraph(new Run(new Text(propertyValue?.ToString() ?? string.Empty))));
|
||||
dataRow.Append(cell);
|
||||
}
|
||||
table.Append(dataRow);
|
||||
}
|
||||
}*/
|
||||
}
|
||||
}
|
||||
|
@ -8,6 +8,7 @@
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="Aspose.Words" Version="24.10.0" />
|
||||
<PackageReference Include="DocumentFormat.OpenXml" Version="3.1.0" />
|
||||
</ItemGroup>
|
||||
|
||||
|
@ -1,16 +0,0 @@
|
||||
namespace ComponentsView
|
||||
{
|
||||
public class DocumentSymple
|
||||
{
|
||||
public string FileUrl { get; set; } = string.Empty;
|
||||
public string FileName { get; set; } = string.Empty;
|
||||
public string[] Text { get; set; }
|
||||
|
||||
public DocumentSymple(string fileUrl, string fileName, string[] text)
|
||||
{
|
||||
FileUrl = fileUrl;
|
||||
FileName = fileName;
|
||||
Text = text;
|
||||
}
|
||||
}
|
||||
}
|
@ -1,31 +0,0 @@
|
||||
|
||||
namespace ComponentsLibrary
|
||||
{
|
||||
public class DocumentTable<T>
|
||||
{
|
||||
public string DocumentTitle { get; set; } = string.Empty;
|
||||
public string DocumentPath { get; set; } = string.Empty;
|
||||
public List<int> MergedColumns { get; set; }
|
||||
public List<double> ColumnWidths { get; set; }
|
||||
public List<string> Headers { get; set; }
|
||||
public List<T> Data { get; set; }
|
||||
public List<string> PropertyMappings { get; set; }
|
||||
|
||||
public DocumentTable(string documentTitle,
|
||||
string documentPath,
|
||||
List<int> mergedColumns,
|
||||
List<double> columnWidths,
|
||||
List<string> headers,
|
||||
List<T> data,
|
||||
List<string> propertyMappings)
|
||||
{
|
||||
DocumentTitle = documentTitle;
|
||||
DocumentPath = documentPath;
|
||||
MergedColumns = mergedColumns;
|
||||
ColumnWidths = columnWidths;
|
||||
Headers = headers;
|
||||
Data = data;
|
||||
PropertyMappings = propertyMappings;
|
||||
}
|
||||
}
|
||||
}
|
@ -1,5 +1,4 @@
|
||||
using ComponentsView;
|
||||
using System.ComponentModel;
|
||||
using System.ComponentModel;
|
||||
using static System.Net.Mime.MediaTypeNames;
|
||||
|
||||
namespace ComponentsLibrary
|
||||
|
10
ComponentsLibrary/entities/ColumnParams.cs
Normal file
10
ComponentsLibrary/entities/ColumnParams.cs
Normal file
@ -0,0 +1,10 @@
|
||||
namespace ComponentsLibrary.entities
|
||||
{
|
||||
public class ColumnParams
|
||||
{
|
||||
public string FirstRowHeader { get; set; } = string.Empty;
|
||||
public string SecondRowHeader { get; set; } = string.Empty;
|
||||
public string PropertyName { get; set; } = string.Empty;
|
||||
public double Width { get; set; }
|
||||
}
|
||||
}
|
16
ComponentsLibrary/entities/DocumentSymple.cs
Normal file
16
ComponentsLibrary/entities/DocumentSymple.cs
Normal file
@ -0,0 +1,16 @@
|
||||
namespace ComponentsLibrary.entities
|
||||
{
|
||||
public class DocumentSymple
|
||||
{
|
||||
public string FileUrl { get; set; } = string.Empty;
|
||||
public string Title { get; set; } = string.Empty;
|
||||
public string[] Text { get; set; }
|
||||
|
||||
public DocumentSymple(string fileUrl, string title, string[] text)
|
||||
{
|
||||
FileUrl = fileUrl;
|
||||
Title = title;
|
||||
Text = text;
|
||||
}
|
||||
}
|
||||
}
|
27
ComponentsLibrary/entities/DocumentTable.cs
Normal file
27
ComponentsLibrary/entities/DocumentTable.cs
Normal file
@ -0,0 +1,27 @@
|
||||
namespace ComponentsLibrary.entities
|
||||
{
|
||||
public class DocumentTable<T>
|
||||
{
|
||||
//путь до файла
|
||||
public string FileUrl { get; set; } = string.Empty;
|
||||
//заголовок в документе
|
||||
public string Title { get; set; } = string.Empty;
|
||||
//параметры колонок (ширина и тд)
|
||||
public List<ColumnParams> ColumnParameters { get; set; } = new();
|
||||
|
||||
//данные для таблицы
|
||||
public List<T> Items { get; set; } = new();
|
||||
|
||||
//информация по объединению колонок
|
||||
public List<int[]> MergedColumns { get; set; } = new();
|
||||
|
||||
public DocumentTable(string fileUrl, string title, List<ColumnParams> columnParameters, List<T> data, List<int[]> mergedColumns)
|
||||
{
|
||||
FileUrl = fileUrl;
|
||||
Title = title;
|
||||
ColumnParameters = columnParameters;
|
||||
Items = data;
|
||||
MergedColumns = mergedColumns;
|
||||
}
|
||||
}
|
||||
}
|
37
ComponentsLibrary/entities/Employee.cs
Normal file
37
ComponentsLibrary/entities/Employee.cs
Normal file
@ -0,0 +1,37 @@
|
||||
namespace ComponentsLibrary.entities
|
||||
{
|
||||
public class Employee
|
||||
{
|
||||
public string Status { get; set; }
|
||||
public string Name { get; set; }
|
||||
public string Surname { get; set; }
|
||||
public string Age { get; set; }
|
||||
public string Childrens { get; set; }
|
||||
public string Car { get; set; }
|
||||
public string Post { get; set; }
|
||||
public string Experience { get; set; }
|
||||
public string Prize { get; set; }
|
||||
|
||||
|
||||
public Employee(string status, string name, string surname, string age,string childrens,string car,string post,string experience,string prize)
|
||||
{
|
||||
Status = status;
|
||||
Name = name;
|
||||
Surname = surname;
|
||||
Age = age;
|
||||
Childrens = childrens;
|
||||
Car = car;
|
||||
Post = post;
|
||||
Experience = experience;
|
||||
Prize = prize;
|
||||
}
|
||||
|
||||
public Employee() { }
|
||||
|
||||
public override string ToString()
|
||||
{
|
||||
string temp = Status + ", " + Name + ", " + Surname + ", " + Age + ", " + Childrens + ", " + Car + ", " + Post + ", " + Experience + ", " + Prize;
|
||||
return temp;
|
||||
}
|
||||
}
|
||||
}
|
20
ComponentsView/FormComponents.Designer.cs
generated
20
ComponentsView/FormComponents.Designer.cs
generated
@ -36,9 +36,7 @@
|
||||
richTextBoxWord = new RichTextBox();
|
||||
buttonSaveTextWord = new Button();
|
||||
componentTable = new ComponentsLibrary.ComponentTable(components);
|
||||
dataGridViewTable = new DataGridView();
|
||||
buttonSaveTable = new Button();
|
||||
((System.ComponentModel.ISupportInitialize)dataGridViewTable).BeginInit();
|
||||
SuspendLayout();
|
||||
//
|
||||
// richTextBoxTest
|
||||
@ -77,22 +75,13 @@
|
||||
buttonSaveTextWord.UseVisualStyleBackColor = true;
|
||||
buttonSaveTextWord.Click += buttonSaveTextWord_Click;
|
||||
//
|
||||
// dataGridViewTable
|
||||
//
|
||||
dataGridViewTable.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.AutoSize;
|
||||
dataGridViewTable.Location = new Point(12, 143);
|
||||
dataGridViewTable.Name = "dataGridViewTable";
|
||||
dataGridViewTable.RowTemplate.Height = 25;
|
||||
dataGridViewTable.Size = new Size(350, 167);
|
||||
dataGridViewTable.TabIndex = 4;
|
||||
//
|
||||
// buttonSaveTable
|
||||
//
|
||||
buttonSaveTable.Location = new Point(12, 316);
|
||||
buttonSaveTable.Location = new Point(12, 143);
|
||||
buttonSaveTable.Name = "buttonSaveTable";
|
||||
buttonSaveTable.Size = new Size(350, 23);
|
||||
buttonSaveTable.Size = new Size(350, 41);
|
||||
buttonSaveTable.TabIndex = 5;
|
||||
buttonSaveTable.Text = "Сохранить";
|
||||
buttonSaveTable.Text = "Cоздать документ с таблицей";
|
||||
buttonSaveTable.UseVisualStyleBackColor = true;
|
||||
buttonSaveTable.Click += buttonSaveTable_Click;
|
||||
//
|
||||
@ -102,14 +91,12 @@
|
||||
AutoScaleMode = AutoScaleMode.Font;
|
||||
ClientSize = new Size(800, 450);
|
||||
Controls.Add(buttonSaveTable);
|
||||
Controls.Add(dataGridViewTable);
|
||||
Controls.Add(buttonSaveTextWord);
|
||||
Controls.Add(richTextBoxWord);
|
||||
Controls.Add(buttonSaveText);
|
||||
Controls.Add(richTextBoxTest);
|
||||
Name = "FormComponents";
|
||||
Text = "Form1";
|
||||
((System.ComponentModel.ISupportInitialize)dataGridViewTable).EndInit();
|
||||
ResumeLayout(false);
|
||||
}
|
||||
|
||||
@ -122,7 +109,6 @@
|
||||
private RichTextBox richTextBoxWord;
|
||||
private Button buttonSaveTextWord;
|
||||
private ComponentsLibrary.ComponentTable componentTable;
|
||||
private DataGridView dataGridViewTable;
|
||||
private Button buttonSaveTable;
|
||||
}
|
||||
}
|
||||
|
@ -1,4 +1,5 @@
|
||||
using System.Windows.Forms;
|
||||
using ComponentsLibrary.entities;
|
||||
|
||||
namespace ComponentsView
|
||||
{
|
||||
@ -8,7 +9,6 @@ namespace ComponentsView
|
||||
{
|
||||
InitializeComponent();
|
||||
testComponent.FileName = "2.txt";
|
||||
InitializeDataGridView();
|
||||
}
|
||||
|
||||
private void buttonSaveText_Click(object sender, EventArgs e)
|
||||
@ -28,55 +28,76 @@ namespace ComponentsView
|
||||
}
|
||||
|
||||
private void buttonSaveTextWord_Click(object sender, EventArgs e)
|
||||
{
|
||||
using var dialog = new SaveFileDialog
|
||||
{
|
||||
Filter = "docx|*.docx"
|
||||
};
|
||||
if (dialog.ShowDialog() == DialogResult.OK)
|
||||
{
|
||||
try
|
||||
{
|
||||
var docEntry = new DocumentSymple(@"\5semestr\KOP\KOP-PIbd-32-Katysheva-N-E\docs", "Word.docx", richTextBoxWord.Lines);
|
||||
componentBigText.SetText(docEntry.FileUrl, docEntry.FileName, docEntry.Text);
|
||||
DocumentSymple doc = new(dialog.FileName, "Êàêîé-òî çàãîëîâîê?", richTextBoxWord.Lines);
|
||||
componentBigText.CreateWordText(doc);
|
||||
MessageBox.Show("Ñîõàðíåíî óñïåøíî", "Ðåçóëüòàò",
|
||||
MessageBoxButtons.OK, MessageBoxIcon.Information);
|
||||
}
|
||||
|
||||
catch (Exception ex)
|
||||
{
|
||||
MessageBox.Show(ex.Message, "Îøèáêà!",
|
||||
MessageBoxButtons.OK, MessageBoxIcon.Error);
|
||||
}
|
||||
}
|
||||
|
||||
private void InitializeDataGridView()
|
||||
{
|
||||
dataGridViewTable.Columns.Add("Column1", "袜玮囗桢");
|
||||
dataGridViewTable.Columns.Add("Column2", "琼圜屙桢");
|
||||
dataGridViewTable.Columns.Add("Column3", "买铕铄 珥圜屙桢");
|
||||
dataGridViewTable.Rows.Add("义耱1", "琼圜屙桢1","2 琼圜屙桢1");
|
||||
dataGridViewTable.Rows.Add("义耱2", "琼圜屙桢2", "2 琼圜屙桢2");
|
||||
dataGridViewTable.Rows.Add("义耱3", "琼圜屙桢3", "2 琼圜屙桢3");
|
||||
dataGridViewTable.Rows.Add("义耱4", "琼圜屙桢4", "2 琼圜屙桢4");
|
||||
dataGridViewTable.Rows.Add("义耱5", "琼圜屙桢5", "2 琼圜屙桢5");
|
||||
dataGridViewTable.Rows.Add("义耱6", "琼圜屙桢6", "2 琼圜屙桢6");
|
||||
}
|
||||
|
||||
private void buttonSaveTable_Click(object sender, EventArgs e)
|
||||
{
|
||||
List<int[]> mergedColumns = new()
|
||||
{
|
||||
new int[] { 1, 5 },
|
||||
new int[] { 6, 7 },
|
||||
};
|
||||
|
||||
var columns = new List<ColumnParams>
|
||||
{
|
||||
new() { FirstRowHeader = "Ñòàòóñ", SecondRowHeader = "", PropertyName = "Status", Width = 1 },
|
||||
new() { FirstRowHeader = "Ëè÷íûå äàííûå", SecondRowHeader = "Èìÿ",PropertyName = "Name", Width = 1 },
|
||||
new() { FirstRowHeader = "Ëè÷íûå äàííûå", SecondRowHeader = "Ôàìèëèÿ", PropertyName = "Surname", Width = 1 },
|
||||
new() { FirstRowHeader = "Ëè÷íûå äàííûå", SecondRowHeader = "Âîçðàñò", PropertyName = "Age", Width = 0.1 },
|
||||
new() { FirstRowHeader = "Ëè÷íûå äàííûå", SecondRowHeader = "Äåòè", PropertyName = "Childrens", Width = 0.1 },
|
||||
new() { FirstRowHeader = "Ëè÷íûå äàííûå", SecondRowHeader = "Ìàøèíà", PropertyName = "Car", Width = 1 },
|
||||
new() { FirstRowHeader = "Ðàáîòà", SecondRowHeader = "Äîëæíîñòü", PropertyName = "Post", Width = 1 },
|
||||
new() { FirstRowHeader = "Ðàáîòà", SecondRowHeader = "Ñòàæ", PropertyName = "Experience", Width = 1 },
|
||||
new() { FirstRowHeader = "Ïðåìèÿ", SecondRowHeader = "", PropertyName = "Prize", Width = 1 },
|
||||
};
|
||||
|
||||
var employees = new List<Employee>
|
||||
{
|
||||
new() { Status = "Active", Name = "John", Surname = "Doe", Age = "35", Childrens = "2", Car = "Toyota", Post = "Manager", Experience = "10 years", Prize = "5000" },
|
||||
new() { Status = "On Leave", Name = "Alice", Surname = "Smith", Age = "28", Childrens = "1", Car = "Honda", Post = "Developer", Experience = "5 years", Prize = "3000" },
|
||||
new() { Status = "Active", Name = "Bob", Surname = "Brown", Age = "40", Childrens = "3", Car = "Ford", Post = "Team Lead", Experience = "15 years", Prize = "7000" },
|
||||
new() { Status = "Retired", Name = "Carol", Surname = "Johnson", Age = "65", Childrens = "4", Car = "None", Post = "Accountant", Experience = "30 years", Prize = "10000" },
|
||||
new() { Status = "Active", Name = "David", Surname = "Wilson", Age = "45", Childrens = "2", Car = "Chevrolet", Post = "Designer", Experience = "20 years", Prize = "4000" },
|
||||
new() { Status = "Active", Name = "Eve", Surname = "Davis", Age = "32", Childrens = "0", Car = "Tesla", Post = "Data Scientist", Experience = "8 years", Prize = "6000" },
|
||||
new() { Status = "On Leave", Name = "Frank", Surname = "Miller", Age = "38", Childrens = "2", Car = "BMW", Post = "Product Manager", Experience = "12 years", Prize = "5500" },
|
||||
new() { Status = "Active", Name = "Grace", Surname = "Taylor", Age = "29", Childrens = "1", Car = "Mercedes", Post = "QA Engineer", Experience = "6 years", Prize = "3500" },
|
||||
new() { Status = "Resigned", Name = "Henry", Surname = "Anderson", Age = "50", Childrens = "3", Car = "Audi", Post = "CTO", Experience = "25 years", Prize = "12000" },
|
||||
new() { Status = "Active", Name = "Ivy", Surname = "Thomas", Age = "27", Childrens = "0", Car = "Volkswagen", Post = "Intern", Experience = "1 year", Prize = "1000" }
|
||||
};
|
||||
|
||||
|
||||
using var dialog = new SaveFileDialog
|
||||
{
|
||||
Filter = "docx|*.docx"
|
||||
};
|
||||
|
||||
if (dialog.ShowDialog() == DialogResult.OK)
|
||||
{
|
||||
try
|
||||
{
|
||||
List<string[]> data = new List<string[]>();
|
||||
|
||||
// 如怆鬻屙桢 溧眄<E6BAA7> 桤 DataGridView
|
||||
foreach (DataGridViewRow row in dataGridViewTable.Rows)
|
||||
{
|
||||
if (row.IsNewRow) continue; // 橡铒篑蜩螯 矬耱簋 耱痤牦
|
||||
string[] rowData = new string[dataGridViewTable.Columns.Count];
|
||||
for (int i = 0; i < dataGridViewTable.Columns.Count; i++)
|
||||
{
|
||||
rowData[i] = row.Cells[i].Value?.ToString() ?? string.Empty;
|
||||
}
|
||||
data.Add(rowData);
|
||||
}
|
||||
|
||||
// 杨玟囗桢 漕牦戾眚<E688BE> <20> 溧眄<E6BAA7><E79C84> 桤 蜞犭桷<E78AAD>
|
||||
var docEntry = new DocumentSymple(@"\5semestr\KOP\KOP-PIbd-32-Katysheva-N-E\docs", "Table.docx", data.Select(row => string.Join("\t", row)).ToArray());
|
||||
componentBigText.SetText(docEntry.FileUrl, docEntry.FileName, docEntry.Text);
|
||||
DocumentTable<Employee> info = new(dialog.FileName, "Çàäàíèå 2", columns, employees, mergedColumns);
|
||||
componentTable.CreateTable(info);
|
||||
|
||||
MessageBox.Show("Ñîõðàíåíî óñïåøíî", "Ðåçóëüòàò",
|
||||
MessageBoxButtons.OK, MessageBoxIcon.Information);
|
||||
@ -89,3 +110,4 @@ namespace ComponentsView
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -126,4 +126,7 @@
|
||||
<metadata name="componentTable.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>308, 17</value>
|
||||
</metadata>
|
||||
<metadata name="componentTable2.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>451, 17</value>
|
||||
</metadata>
|
||||
</root>
|
@ -13,120 +13,8 @@ namespace ComponentsView
|
||||
{
|
||||
// To customize application configuration such as set high DPI settings or default font,
|
||||
// see https://aka.ms/applicationconfiguration.
|
||||
//ApplicationConfiguration.Initialize();
|
||||
//Application.Run(new FormComponents());
|
||||
|
||||
const string fileName = @"AddTable.docx";
|
||||
const string fileUrl = @"\5semestr\KOP\KOP-PIbd-32-Katysheva-N-E";
|
||||
AddTable();
|
||||
|
||||
static void AddTable() {
|
||||
|
||||
|
||||
using (WordprocessingDocument document = WordprocessingDocument.Create(Path.Combine(fileUrl, fileName), WordprocessingDocumentType.Document))
|
||||
{
|
||||
|
||||
//var doc = document.MainDocumentPart.Document;
|
||||
MainDocumentPart mainPart = document.AddMainDocumentPart();
|
||||
mainPart.Document = new Document();
|
||||
Body body = new Body();
|
||||
|
||||
Table table = new Table();
|
||||
|
||||
TableProperties props = new TableProperties(
|
||||
new TableBorders(
|
||||
new TopBorder
|
||||
{
|
||||
Val = new EnumValue<BorderValues>(BorderValues.Single),
|
||||
Size = 12
|
||||
},
|
||||
new BottomBorder
|
||||
{
|
||||
Val = new EnumValue<BorderValues>(BorderValues.Single),
|
||||
Size = 12
|
||||
},
|
||||
new LeftBorder
|
||||
{
|
||||
Val = new EnumValue<BorderValues>(BorderValues.Single),
|
||||
Size = 12
|
||||
},
|
||||
new RightBorder
|
||||
{
|
||||
Val = new EnumValue<BorderValues>(BorderValues.Single),
|
||||
Size = 12
|
||||
},
|
||||
new InsideHorizontalBorder
|
||||
{
|
||||
Val = new EnumValue<BorderValues>(BorderValues.Single),
|
||||
Size = 12
|
||||
},
|
||||
new InsideVerticalBorder
|
||||
{
|
||||
Val = new EnumValue<BorderValues>(BorderValues.Single),
|
||||
Size = 12
|
||||
}
|
||||
)
|
||||
);
|
||||
table.AppendChild<TableProperties>(props);
|
||||
|
||||
var headerRow = new TableRow();
|
||||
for (var j = 0; j <= 3; j++)
|
||||
{
|
||||
var tc = new TableCell();
|
||||
|
||||
|
||||
|
||||
TableCellProperties cellProps = new TableCellProperties();
|
||||
TableCellWidth cellWidth = new TableCellWidth() { Type = TableWidthUnitValues.Auto };
|
||||
cellProps.Append(cellWidth);
|
||||
|
||||
if (j == 0)
|
||||
{
|
||||
GridSpan gridSpan = new GridSpan() { Val = 3 };
|
||||
cellProps.Append(gridSpan);
|
||||
}
|
||||
if (j == 1 || j == 2)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
RunProperties headerRunProperties = new RunProperties();
|
||||
Bold bold = new Bold();
|
||||
headerRunProperties.Append(bold);
|
||||
|
||||
string headerText = "Column " + j;
|
||||
Run run = new Run(new Text(headerText));
|
||||
run.PrependChild<RunProperties>(headerRunProperties);
|
||||
|
||||
|
||||
tc.Append(new Paragraph(run));
|
||||
tc.Append(cellProps);
|
||||
headerRow.Append(tc);
|
||||
}
|
||||
table.Append(headerRow);
|
||||
|
||||
for (var i = 0; i <= 3; i++)
|
||||
{
|
||||
var tr = new TableRow();
|
||||
for (var j = 0; j <= 3; j++)
|
||||
{
|
||||
var tc = new TableCell();
|
||||
string data = "info" + i;
|
||||
tc.Append(new Paragraph(new Run(new Text(data))));
|
||||
tc.Append(new TableCellProperties(new TableCellWidth { Type = TableWidthUnitValues.Auto }));
|
||||
tr.Append(tc);
|
||||
}
|
||||
table.Append(tr);
|
||||
}
|
||||
|
||||
body.Append(table);
|
||||
|
||||
mainPart.Document.Append(body);
|
||||
mainPart.Document.Save();
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
ApplicationConfiguration.Initialize();
|
||||
Application.Run(new FormComponents());
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user