Я столкнулся с проблемой на днях, когда попытался использовать модуль отображения 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, но я надеюсь, что смогу что-нибудь понять.