7

Web スクレイパーに接続された SVG ファイルを作成しようとしています。

svgwrite でフォントとテキスト サイズを変更するにはどうすればよいですか? CSS スタイルを定義し、何らかの方法でそれをテキスト オブジェクトに接続する必要があることを理解しています。しかし、これはどのように作られていますか?

ここに私がこれまでに持っているコードがあります

import svgwrite

svg_document = svgwrite.Drawing(filename = "test-svgwrite3.svg",
                            size = ("1200px", "800px"))
#This is the line I'm stuck at
#svg_document.add(svg_document.style('style="font-family: Arial; font-size  : 34;'))

svg_document.add(svg_document.rect(insert = (900, 800),
                                   size = ("200px", "100px"),
                                   stroke_width = "1",
                                   stroke = "black",
                                   fill = "rgb(255,255,0)"))

svg_document.add(svg_document.text("Reported Crimes in Sweden",
                                   insert = (410, 50),
                                   fill = "rgb(255,255,0)",

                                  #This is the connection to the first line that I'm stuck at
                                  #style = 'style="font-family: Arial; font-size  : 104;'))

print(svg_document.tostring())

svg_document.save()
4

3 に答える 3

11

SvgWrite の作成者である Manfred Moitzi は、より洗練された回答を私にメールしてくれました。

これは CSS で行う必要があります。'class_' または 'style' キーワード引数を使用してテキスト プロパティを設定します。

dwg = svgwrite.Drawing()

「style」キーワード引数を使用:

g = dwg.g(style="font-size:30;font-family:Comic Sans MS, Arial;font-weight:bold;font-
style:oblique;stroke:black;stroke-width:1;fill:none")

g.add(dwg.text("your text", insert=(10,30))) # settings are valid for all text added to 'g'
dwg.add(g)

「class_」キーワード引数を使用:

コンテンツを含む CSS ファイルを作成します。

.myclass {
font-size:30;
font-family:Comic Sans MS, Arial;
font-weight:bold;
font-style:oblique;
stroke:black;
stroke-width:1;
fill:none;
}

CSS リファレンスを参照してください: http://www.w3schools.com/cssref/default.asp

dwg.add_stylesheet(filename, title="sometext") # same rules as for html files

g = dwg.g(class_="myclass")
g.add(dwg.text("your text", insert=(10,30))) # settings are valid for all text added to 'g'
dwg.add(g)

「class_」および「style」キーワード引数を使用すると、すべてのグラフィック オブジェクトのスタイルを設定でき、コンテナ オブジェクトで使用できます。

于 2013-06-18T15:01:24.833 に答える
5

答えは非常に簡単でした。

svg_document.add(svg_document.text("Reported Crimes in Sweden",
                                   insert = (410, 50),
                                   fill = "rgb(255,255,0)",
                                   style = "font-size:10px; font-family:Arial"))
于 2013-06-17T21:05:34.237 に答える
2

次のように font-size を設定します。

dwg = svgwrite.Drawing('test.svg', profile='tiny')
dwg.add(dwg.text('Test',insert = (30, 55),font_size="10px",fill='black'))
于 2015-08-30T14:54:06.167 に答える