Это все в теме. Я использую (длинную) строку из файла данных в качестве заголовка, а Gnuplot не переносит ее.
Я не знаю содержимого строки заранее, поэтому я не знаю, как мне просто вставить a \n
. Как я могу заставить Gnuplot обернуть заголовок?
Это все в теме. Я использую (длинную) строку из файла данных в качестве заголовка, а Gnuplot не переносит ее.
Я не знаю содержимого строки заранее, поэтому я не знаю, как мне просто вставить a \n
. Как я могу заставить Gnuplot обернуть заголовок?
Ответы:
Вы должны отредактировать данные в вашем файле и вставить \n
в поле, откуда анализируется заголовок.
Gnuplot распознает \n
и разорвет линию в этой точке. В противном случае вам нужно вручную ввести заголовок и добавить \n
в нужную вам позицию.
Важно отметить, что \n
gnuplot учитывает это только при наличии "string"
вместо 'string'
.
Если вы не можете редактировать данные в вашем файле, вы можете использовать строковые функции в gnuplot. С помощью strlen("string")
вы можете найти длину вашей строки, а затем с помощью substr("string",begin,end)
вас можно разделить строки.
Вот полный список функций gnuplot:
http://gnuplot.sourceforge.net/docs_4.2/node53.html
В итоге у вас будет что-то вроде
foo = "my data"
length = strlen(foo) #get string length
length2 = sprintf("%1.d", length / 2) #round halved down string length to find center char
foo1 = substr(foo, 0, length2) #get first half of string
foo2 = substr(foo, length2, length) #get second half of string
titlestring = foo1.\n.foo2 #make new title string with newline character
Для получения дополнительной информации обратитесь к демонстрационному сценарию строковой переменной gnuplot:
http://gnuplot.sourceforge.net/demo/stringvar.html
где приведены такие примеры:
#
# Miscellaneous neat things you can do using the string variables code
#
set print "stringvar.tmp"
print ""
print "Exercise substring handling"
print ""
beg = 2
end = 4
print "beg = ",beg," end = ",end
foo = "ABCDEF"
print "foo = ",foo
print "foo[3:5] = ",foo[3:5]
print "foo[1:1] = ",foo[1:1]
print "foo[5:3] = ",foo[5:3]
print "foo[beg:end] = ",foo[beg:end]
print "foo[end:beg] = ",foo[end:beg]
print "foo[5:] = ",foo[5:]
print "foo[5:*] = ",foo[5:*]
print "foo[:] = ",foo[:]
print "foo[*:*] = ",foo[*:*]
print "foo.foo[2:2] = ",foo.foo[2:2]
print "(foo.foo)[2:2]= ",(foo.foo)[2:2]
print ""
print "foo[1:1] eq 'A' && foo[2:2] ne 'X' = ", \
(foo[1:1] eq 'A' && foo[2:2] ne 'X') ? "true" : "false"
unset print
set label 1 system("cat stringvar.tmp") at graph 0.1, graph 0.9
unset xtics
unset ytics
set yrange [0:1]
plot 0
Вместе с функцией strlen
вы сможете создать свое решение для автоматической обработки ваших данных в gnuplot и разместить символ новой строки там, где вы хотите (например, после каждого 20-го символа).
Если вы хотите разбить слова, вы должны использовать:
wordnumber = word(foo) #get number of words
wordernumber2 = sprintf("%1.d", wordnumber / 2) #round down half of #words
do for [i=0:wordnumber2] { #add half of words to string
string = string.word(foo,i)
}
string = string.\n #add newline to string
do for [i=wordnumber2:wordnumber] { #add 2nd half of words
string = string.word(foo,i)
}
Для этого требуется gnuplot 4.4+
\n
!»
words("string")
возвращает количество слов в строке. word("string",n)
возвращает n-е слово в строке. Однако длинные слова (особенно в немецком, но также составные слова в английском) могут потенциально превышать количество символов, разрешенных в одной строке. Поэтому вырезание на основе символов лучше для неизвестной строки. Со словами это привело бы к сложной программе, которую я бы предпочел использовать на языках сценариев, таких как perl / python. Предварительная обработка файлов, вставка новых строк (в дополнение к другому форматированию) более простым способом.