Я зіткнувся з проблемою на днях, коли я намагався використовувати модуль відображення ArcPy для редагування текстових елементів прямокутника з новими рядками (\ n) у документі ArcMap. Ось як виглядав результат:
Ось код, який я використав для отримання цього результату. Перший стовпчик - це текстові елементи прямокутника Text1, Text2, Text3, що йде вниз; другий стовпець - це "прості" текстові елементи Text4, Text5 та Text6, що йдуть вниз.
import os
import arcpy
HomeDir = r"C:\Desktop"
arcpy.env.workspace = HomeDir
CurrentMXD = arcpy.mapping.MapDocument(r"C:\Desktop\TextTest.mxd")
OutputFilename = r"C:\Desktop\TextTest.pdf"
if os.path.exists(OutputFilename):
os.remove(OutputFilename)
for TextElement in arcpy.mapping.ListLayoutElements(CurrentMXD, "TEXT_ELEMENT"):
TextElementName = TextElement.name
String1 = "The quick brown fox jumped over the lazy dog.\nShe sells sea shells by the sea shore."
String2 = "The quick brown fox \njumped over the lazy dog.\nShe sells sea shells by the sea shore."
String3 = "The quick brown fox jumped \nover the lazy dog.\nShe sells sea shells by the sea shore."
if TextElementName == "Text1":
TextElement.text = String1
if TextElementName == "Text2":
TextElement.text = String2
if TextElementName == "Text3":
TextElement.text = String3
if TextElementName == "Text4":
TextElement.text = String1
if TextElementName == "Text5":
TextElement.text = String2
if TextElementName == "Text6":
TextElement.text = String3
arcpy.mapping.ExportToPDF(CurrentMXD, OutputFilename)
Поки, схоже, наявність переплутаного тексту залежить від того, чи буде лінія довшою, щоб обернути її, і чи довше рядка перед новим рядком, ніж рядок після нового рядка.
Будь-які ідеї про те, що може піти не так? Чи існує рішення? Я міг би використовувати елементи простого тексту та хвилюватися щодо обгортання ліній за допомогою Python, але сподіваюся, що зможу щось зрозуміти.