Go LIbrary для создания и редактирования документов MS Word
Библиотека Go с открытым исходным кодом для управления и автоматизации общих задач обработки Word, таких как вставка верхнего и нижнего колонтитула, таблиц и изображений в файлы Word DOCX и многое другое.
unioffice — это мощная библиотека Go с открытым исходным кодом, которая позволяет разработчикам программного обеспечения легко управлять текстовыми документами и автоматизировать общие задачи обработки текстов в своих собственных приложениях, не требуя Microsoft Word. Библиотека достаточно хорошо оптимизирована и позволяет легко редактировать код под свои требования.
Библиотека unioffice — это мощная библиотека на основе Go, которую можно использовать для создания, редактирования, форматирования и обработки документов Office Open XML. Библиотека поддерживает несколько важных функций обработки текстов, таких как чтение, запись и изменение документов Word, поддержка форматирования текста, автоматическое создание оглавления, размещение на странице документа, вставка верхних и нижних колонтитулов, добавление таблиц, открытие документа как шаблона. , поддержка полей формы и многое другое.
Начало работы с юниофис
Рекомендуемый способ установить unioffice в ваш проект – использовать GitHub. Пожалуйста, используйте следующую команду для плавной установки.
Установить юниофис через GitHub
go get github.com/unidoc/unioffice/
go build -i github.com/unidoc/unioffice/...
Создайте документ Word DOCX через Go API
Библиотека с открытым исходным кодом unioffice предоставила возможность легко создать новый документ Word DOCX. Вы также можете легко открывать и изменять существующий документ Microsoft Word в своих собственных приложениях. Библиотека также включала функции для добавления новых текстовых абзацев, вставки изображений на страницу, выравнивания текста, добавления верхних и нижних колонтитулов, добавления таблиц и многого другого.
Свойства доступа к документу Word через Go API
func main() {
doc, err := document.Open("document.docx")
if err != nil {
log.Fatalf("error opening document: %s", err)
}
defer doc.Close()
cp := doc.GetOrCreateCustomProperties()
// You can read properties from the document
fmt.Println("AppVersion", *cp.GetPropertyByName("AppVersion").X().Lpwstr)
fmt.Println("Company", *cp.GetPropertyByName("Company").X().Lpwstr)
fmt.Println("DocSecurity", *cp.GetPropertyByName("DocSecurity").X().I4)
fmt.Println("LinksUpToDate", *cp.GetPropertyByName("LinksUpToDate").X().Bool)
fmt.Println("Non-existent", cp.GetPropertyByName("nonexistentproperty"))
// And change them as well
cp.SetPropertyAsLpwstr("Company", "Another company") // text, existing property
fmt.Println("Company", *cp.GetPropertyByName("Company").X().Lpwstr)
// Adding new properties
cp.SetPropertyAsLpwstr("Another text property", "My text value") // text
cp.SetPropertyAsI4("Another integer number property", 42) // int32
cp.SetPropertyAsR8("Another float number property", 3.14) // float64
cp.SetPropertyAsDate("Another date property", time.Now()) // date
doc.SaveToFile("document_customized.docx")
// For new documents all is the same
docNew := document.New()
defer docNew.Close()
cpNew := docNew.GetOrCreateCustomProperties()
cpNew.SetPropertyAsLpwstr("Another text property", "My text value") // text
cpNew.SetPropertyAsI4("Another integer number property", 42) // int23
cpNew.SetPropertyAsR8("Another float number property", 3.14) // float64
cpNew.SetPropertyAsDate("Another date property", time.Now()) // date
docNew.SaveToFile("document_new.docx")
}
Вставка изображений в файлы Word DOCX
Библиотека с открытым исходным кодом unioffice предоставляет разработчикам программного обеспечения возможность использовать изображения в документах Microsoft Word. Он поддерживает такие функции, как вставка изображений в выбранное вами место, изменение существующего изображения, обтекание изображения текстом, удаление изображения и многое другое. Для добавления изображения необходимо указать имя и местоположение изображения.
Управление изображениями в Word Documents через Go API
func main() {
doc := document.New()
defer doc.Close()
img1, err := common.ImageFromFile("gophercolor.png")
if err != nil {
log.Fatalf("unable to create image: %s", err)
}
img2data, err := ioutil.ReadFile("gophercolor.png")
if err != nil {
log.Fatalf("unable to read file: %s", err)
}
img2, err := common.ImageFromBytes(img2data)
if err != nil {
log.Fatalf("unable to create image: %s", err)
}
img1ref, err := doc.AddImage(img1)
if err != nil {
log.Fatalf("unable to add image to document: %s", err)
}
img2ref, err := doc.AddImage(img2)
if err != nil {
log.Fatalf("unable to add image to document: %s", err)
}
para := doc.AddParagraph()
anchored, err := para.AddRun().AddDrawingAnchored(img1ref)
if err != nil {
log.Fatalf("unable to add anchored image: %s", err)
}
anchored.SetName("Gopher")
anchored.SetSize(2*measurement.Inch, 2*measurement.Inch)
anchored.SetOrigin(wml.WdST_RelFromHPage, wml.WdST_RelFromVTopMargin)
anchored.SetHAlignment(wml.WdST_AlignHCenter)
anchored.SetYOffset(3 * measurement.Inch)
anchored.SetTextWrapSquare(wml.WdST_WrapTextBothSides)
run := para.AddRun()
for i := 0; i < 16; i++ {
run.AddText(lorem)
// drop an inline image in
if i == 13 {
inl, err := run.AddDrawingInline(img1ref)
if err != nil {
log.Fatalf("unable to add inline image: %s", err)
}
inl.SetSize(1*measurement.Inch, 1*measurement.Inch)
}
if i == 15 {
inl, err := run.AddDrawingInline(img2ref)
if err != nil {
log.Fatalf("unable to add inline image: %s", err)
}
inl.SetSize(1*measurement.Inch, 1*measurement.Inch)
}
}
doc.SaveToFile("image.docx")
}
Добавить верхний и нижний колонтитулы в документ Word
Верхние и нижние колонтитулы можно использовать для включения информации, которую пользователи хотят отображать на каждой странице документа, такой как имя автора, название документа или номера страниц. Библиотека unioffice позволяет разработчикам программного обеспечения с легкостью добавлять верхние и нижние колонтитулы к документам Word. Это также позволяет иметь разные верхние и нижние колонтитулы в зависимости от раздела документа. Он также включал поддержку четных, нечетных и первых функций.
Добавить заголовок & Footer в Word Document через Go API
func main() {
doc := document.New()
defer doc.Close()
img, err := common.ImageFromFile("gophercolor.png")
if err != nil {
log.Fatalf("unable to create image: %s", err)
}
hdr := doc.AddHeader()
// We need to add a reference of the image to the header instead of to the
// document
iref, err := hdr.AddImage(img)
if err != nil {
log.Fatalf("unable to to add image to document: %s", err)
}
para := hdr.AddParagraph()
para.Properties().AddTabStop(2.5*measurement.Inch, wml.ST_TabJcCenter, wml.ST_TabTlcNone)
run := para.AddRun()
run.AddTab()
run.AddText("My Document Title")
imgInl, _ := para.AddRun().AddDrawingInline(iref)
imgInl.SetSize(1*measurement.Inch, 1*measurement.Inch)
// Headers and footers are not immediately associated with a document as a
// document can have multiple headers and footers for different sections.
doc.BodySection().SetHeader(hdr, wml.ST_HdrFtrDefault)
ftr := doc.AddFooter()
para = ftr.AddParagraph()
para.Properties().AddTabStop(6*measurement.Inch, wml.ST_TabJcRight, wml.ST_TabTlcNone)
run = para.AddRun()
run.AddText("Some subtitle goes here")
run.AddTab()
run.AddText("Pg ")
run.AddField(document.FieldCurrentPage)
run.AddText(" of ")
run.AddField(document.FieldNumberOfPages)
doc.BodySection().SetFooter(ftr, wml.ST_HdrFtrDefault)
lorem := `Lorem ipsum dolor sit amet, consectetur adipiscing elit. Proin lobortis, lectus dictum feugiat tempus, sem neque finibus enim, sed eleifend sem nunc ac diam. Vestibulum tempus sagittis elementum`
for i := 0; i < 5; i++ {
para = doc.AddParagraph()
run = para.AddRun()
run.AddText(lorem)
}
doc.SaveToFile("header-footer.docx")
}
Работа с таблицами в Word DOCX
Библиотека с открытым исходным кодом unioffice позволяет программистам добавлять и изменять таблицы внутри текстовых документов. Таблицы очень полезны и могут быть использованы для организации и представления данных в лучшем виде. Он поддерживает добавление таблицы с границами и без них, а также позволяет легко создавать стиль таблицы. Вы можете легко поместить контент в таблицу и настроить размер в соответствии с вашими потребностями.