books-read.com
books-read.com » Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Наш ресурс дает возможность бесплатно читать книгу онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю. Жанр: Базы данных . Сайт books-read.com дает возможность читать полную версию книги без регистрации и sms. Все книги онлайн, не надо качать fb2, epub, txt.
Добавить книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю в приложение ЧИТАТЬ КНИГУ ОФЛАЙН в приложении ios/android
Перейти на страницу:

Дополнительной сложностью при работе с взаимодействием с СОМ и .NET 5 является отсутствие поддержки на этапе компиляции и во время выполнения. Версия MSBuild в .NET 5 не способна распознавать библиотеки взаимодействия, поэтому проекты .NET Core, в которых задействовано взаимодействие с СОМ, не могут компилироваться с применением интерфейса командной строки .NET Core. Они должны компилироваться с использованием Visual Studio, и скомпилированный исполняющий файл можно будет запускать вполне ожидаемым способом.

Взаимодействие с СОМ с использованием динамических данных C#

Чтобы продемонстрировать, каким образом необязательные аргументы, именованные аргументы и ключевое слово

dynamic
совместно способствуют упрощению взаимодействия с СОМ, будет построено приложение, в котором применяется объектная модель Microsoft Office. Добавьте новый файл класса по имени
Car.cs
, содержащий такой код:

namespace ExportDataToOfficeApp

{

  public class Car

  {

    public string Make { get; set; }

    public string Color { get; set; }

    public string PetName { get; set; }

  }

}

Поместите в начало файла

Program.cs
следующие операторы
using
:

using System;

using System.Collections.Generic;

using System.Reflection;

using Excel = Microsoft.Office.Interop.Excel;

using ExportDataToOfficeApp;

Обратите внимание на псевдоним

Excel
для пространства имен
Microsoft.Office.Interop.Excel
. Хотя при взаимодействии с библиотеками СОМ псевдоним определять не обязательно, это обеспечивает наличие более короткого квалификатора для всех импортированных объектов СОМ. Он не только снижает объем набираемого кода, но также разрешает проблемы, когда объекты СОМ имеют имена, конфликтующие с именами типов .NET Core.

Далее создайте список записей

Car
в операторах верхнего уровня внутри файла
Program.cs
:

// Создать псевдоним для объектной модели Excel.

using Excel = Microsoft.Office.Interop.Excel;

Next, create a list of Car records in the top-level statements in Program.cs:

List<Car> carsInStock = new List<Car>

{

  new Car {Color="Green", Make="VW", PetName="Mary"},

  new Car {Color="Red", Make="Saab", PetName="Mel"},

  new Car {Color="Black", Make="Ford", PetName="Hank"},

  new Car {Color="Yellow", Make="BMW", PetName="Davie"}

}

Поскольку вы импортировали библиотеку СОМ с использованием Visual Studio, сборка PIA автоматически сконфигурирована так, что используемые метаданные будут встраиваться в приложение .NET Core. Таким образом, все типы данных

Variant
из СОМ реализуются как типы данных
dynamic
. Взгляните на показанную ниже реализацию метода
ExportToExcel()
:

void ExportToExcel(List<Car> carsInStock)

{

<b>  // Загрузить Excel и затем создать новую пустую рабочую книгу.</b>

  Excel.Application excelApp = new Excel.Application();

  excelApp.Workbooks.Add();

<b>  // В этом примере используется единственный рабочий лист.</b>

  Excel._Worksheet workSheet = (Excel._Worksheet)excelApp.ActiveSheet;

<b>  // Установить заголовки столбцов в ячейках.</b>

  workSheet.Cells[1, &quot;A&quot;] = &quot;Make&quot;;

  workSheet.Cells[1, &quot;B&quot;] = &quot;Color&quot;;

  workSheet.Cells[1, &quot;C&quot;] = &quot;Pet Name&quot;;

<b>  // Сопоставить все данные из List&lt;Car&gt; с ячейками электронной таблицы.</b>

  int row = 1;

  foreach (Car c in carsInStock)

  {

    row++;

    workSheet.Cells[row, &quot;A&quot;] = c.Make;

    workSheet.Cells[row, &quot;B&quot;] = c.Color;

    workSheet.Cells[row, &quot;C&quot;] = c.PetName;

  }

<b>  // Придать симпатичный вид табличным данным.</b>

  workSheet.Range[&quot;A1&quot;].AutoFormat

      (Excel.XlRangeAutoFormat.xlRangeAutoFormatClassic2);

<b>  // Сохранить файл, завершить работу Excel и отобразить сообщение пользователю.</b>

  workSheet.SaveAs($@&quot;{Environment.CurrentDirectory}Inventory.xlsx&quot;);

   excelApp.Quit();

  Console.WriteLine(&quot;The Inventory.xslx file has been saved to your app folder&quot;);

                  // Файл Inventory.xslx сохранен в папке приложения.

}

Метод

ExportToExcel()
начинается с загрузки приложения
Excel
в память; однако на рабочем столе оно не отобразится. В данном приложении нас интересует только работа с внутренней объектной моделью
Excel
. Тем не менее, если необходимо отобразить пользовательский интерфейс
Excel
, тогда метод понадобится дополнить следующим кодом:

Перейти на страницу:

Троелсен Эндрю читать все книги автора по порядку

Троелсен Эндрю - на сайте онлайн книг books-read.com Вы можете читать полные версии книг автора в одном месте.


Язык программирования C#9 и платформа .NET5 отзывы

Отзывы читателей о книге Язык программирования C#9 и платформа .NET5, автор: Троелсен Эндрю. Читайте комментарии и мнения людей о произведении.


Уважаемые читатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.

  • 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
  • 2. Просьба отказаться от оскорблений, угроз и запугиваний.
  • 3. Просьба отказаться от нецензурной лексики.
  • 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.

Надеемся на Ваше понимание и благоразумие. С уважением, администратор books-read.com


Прокомментировать
Подтвердите что вы не робот:*