public void createCongratulationsDoc(WishesGenerator wishesGenerator, List <string> names) { for (int j = 0; j < names.Count; j++) { wishesGenerator.newTrio(); WordApp.ActiveDocument.Bookmarks["Name"].Range.Text = names[j]; for (int i = 0; i < 3; i++) { WordApp.ActiveDocument.Bookmarks[$"Wish{i + 1}"].Range.Text = (wishesGenerator.WishesTrio)[i]; } if (j + 1 < names.Count) { WordApp.Selection.EndKey(Word.WdUnits.wdStory); WordApp.Selection.InsertNewPage(); WordApp.Selection.InsertFile(templateName); } } if (fontName != null) { WordApp.Selection.WholeStory(); WordApp.Selection.Font.Name = fontName; } Directory.CreateDirectory(nameDirectory); string nameF = Directory.GetCurrentDirectory() + "\\" + nameDirectory + "\\" + nameFile; int number = 0; while (File.Exists(nameF + number + ".docx")) { number++; } WordApp.ActiveDocument.SaveAs2(nameF + number + ".docx"); }
static void Main(string[] args) { string settingsFileName = @"C:\Users\35498\source\repos\New_yap_16.01.20\wishes.xlsx"; List <List <string> > wishes; List <string> names; Console.WriteLine("Стандартный пут к файлу Excel? д/н"); if (Console.ReadLine() == "н") { Console.WriteLine("Введите путь: "); settingsFileName = Console.ReadLine(); } Console.WriteLine($"Установленный путь: {settingsFileName}"); ExcelSettingReader excelSettingReader = new ExcelSettingReader(settingsFileName); Console.WriteLine($"Чтение имени файла шаблона из листа {excelSettingReader.settingSheetName} в ячейке {excelSettingReader.xTemplateName} {excelSettingReader.yTemplateName}..."); WordWishesWriter wordWishesWriter = new WordWishesWriter(excelSettingReader.TemplateName); wordWishesWriter.fontName = excelSettingReader.FontName; Console.WriteLine($"Чтение имён с листа {excelSettingReader.namesSheetName}..."); names = excelSettingReader.GetNames(); if (names.Count < 1) { Console.WriteLine($"Нет имён :\\"); Console.ReadKey(); excelSettingReader.closeApp(); return; } Console.WriteLine($"Чтение пожеланий с листа {excelSettingReader.wishesSheetName}..."); wishes = excelSettingReader.GetWishes(); excelSettingReader.closeApp(); if (wishes.Count < 3) { Console.WriteLine($"Слишком мало групп пожеланий!!!"); Console.ReadKey(); return; //throw new ArgumentException("Слишком мало тем пожеланий"); } WishesGenerator wishesGenerator = new WishesGenerator(wishes); if (!wishesGenerator.isThereEnoughtCombination(names.Count())) { Console.WriteLine($"Слишком мало пожеланий для такого количества имён!!!"); Console.ReadKey(); return; } Console.WriteLine($"Генерация пожеланий..."); wishesGenerator.generateWishes(); //wishesGenerator.writeAllCombinations(); Console.WriteLine($"Сброс комбинаций в файл Docx"); wordWishesWriter.createCongratulationsDoc(wishesGenerator, names); wordWishesWriter.showWord(); Console.WriteLine($"Для выхода нажмите любую кнопку..."); Console.ReadKey(); }