SVG映射坐标

建议先看:
5分钟看懂SVG反爬虫原理与绕过实战 | 知了干货分享
https://blog.csdn.net/jspython/article/details/106071233
在这里插入图片描述
效果如下:
在这里插入图片描述
从浏览器的效果可以看出,x=0,文字已经剪贴屏幕左边了,而y=11,文字已经靠顶了。如果y=0,第一行文字就消失了。我也不知道为什么。
因此,根据字符大小,根据这y的差额,假设第一行文字y=13,那么CSS文件就设置-1px,相差不大也可以。不能设置为-13,否则无法显示。字符大小:14px。

demo.html:

<html>
<head>
    <link type="text/css" rel="stylesheet" href="zhiliao.css">
</head>
<body>
<d class="lhttest"></d>
</body>
</html>

zhiliao.css:

d[class^="lht"]{
    width: 14px;
    height: 14px;
    margin-top:90px;
    background-image: url(zhiliao.svg);
    background-repeat: no-repeat;
    display: inline-block;
    background-color: chartreuse; 
    margin-left: 60px;    
}
.lhttest {
    background:-14px -1px;
}

zhiliao.svg:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" width="650px" height="230.0px">
<style>text {font-family:PingFangSC-Regular,Microsoft YaHei,'Hiragino Sans GB',Helvetica;font-size:14px;fill:red;}</style>
<text x='0 14 28 42 56 70 84 98 112 126 140 154' y='13'>如果是中文呢,效果如何</text> 
<text x='14 28 42 56 70 84 98 112 126 140 154' y='70'>Hello,world</text> 
<text x='14 28 42 56 70 84 98 112 126 140 154' y='110'>神探夏洛克,歌神陈奕迅</text> 
<text x='14 28 42 56 70 84 98 112 126 140 154' y='150'>甜美女声任然月球下的人</text> 
</svg>

效果如下:
在这里插入图片描述

import re
css_class_name='lhttest'
pile='.%s{background:-(\d+)px-(\d+)px;}' % css_class_name
pattern=re.compile(pile)
css_resp="""
d[class^="lht"]{
    width: 14px;
    height: 14px;
    margin-top:90px;
    background-image: url(zhiliao.svg);
    background-repeat: no-repeat;
    display: inline-block;
    background-color: chartreuse; 
    margin-left: 60px;    
}
.lhttest {
    background:-14px -1px;
}
"""
css=css_resp.replace('\n','').replace(' ','')
coord=pattern.findall(css)
if coord:
    x,y=coord[0]
    x,y=int(x),int(y)
from parsel import Selector
svg_resp="""
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" width="650px" height="230.0px">
<style>text {font-family:PingFangSC-Regular,Microsoft YaHei,'Hiragino Sans GB',Helvetica;font-size:14px;fill:red;}</style>
<text x='0 14 28 42 56 70 84 98 112 126 140 154' y='13'>如果是中文呢,效果如何</text> 
<text x='14 28 42 56 70 84 98 112 126 140 154' y='70'>Hello,world</text> 
<text x='14 28 42 56 70 84 98 112 126 140 154' y='110'>神探夏洛克,歌神陈奕迅</text> 
<text x='14 28 42 56 70 84 98 112 126 140 154' y='150'>甜美女声任然月球下的人</text> 
</svg>
"""
svg_data=Selector(svg_resp)
texts=svg_data.xpath('//text')
axis_y=[i.attrib.get('y') for i in texts if y<=int(i.attrib.get('y'))][0]
svg_text=svg_data.xpath('//text[@y="{}"]/text()'.format(axis_y)).extract_first()
font_size=re.search('font-size:(\d+)px',svg_resp).group(1)
position=x//int(font_size)
target=svg_text[position]
print(target)  #果

参考资料:Python3反爬虫原理与绕过实战–韦世东
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值