Chrome 行情抓取插件
Chrome 行情抓取插件
上班想偷偷摸摸看行情?自己动手写插件啊,尝试写了一个,新建文件夹,命名为StockMonitor,放入文件如下:
- 3个.png图标文件,19X19、48X48、128X128,命名为19、48、128用作插件图标
- manifest.json:配置文件
{
"update_url": "https://clients2.google.com/service/update2/crx",
"name": "StockMonitor",
"version": "1.0.0",
"description": "StockMonitor",
"manifest_version": 1,
"browser_action": {
"default_icon": "19.png",
"default_title": "StockMonitor",
"default_popup": "popup.html"
},
"icons": {
"16": "19.png",
"48": "48.png",
"128": "128.png"
},
"permissions": [
"http://hq.sinajs.cn/",
"storage"
]
}
- popup.html:插件主界面
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>
table {
width: 150px;
font-size: 10px;
text-align: center;
}
table tr th {
font-family: 'Courier New', Courier, monospace;
font-size: 12px;
}
.tr-red {
color: red;
}
.tr-green {
color: green;
}
</style>
</head>
<div id="maincontent">
<table>
<tr>
<th>名称</th>
<th>现价</th>
<th>涨幅</th>
</tr>
<tr id="510300">
<td>300ETF</td>
<td>0.000</td>
<td>-0.00%</td>
</tr>
<tr id="601288">
<td>农业银行</td>
<td>0.000</td>
<td>+0.00%</td>
</tr>
<tr id="000157">
<td>中联重科</td>
<td>0.000</td>
<td>+0.00%</td>
</tr>
</table>
</div>
<div>
<script type="text/javascript" charset="utf-8" src='jquery.min.js'></script>
<script type="text/javascript" charset="utf-8" src='refresh.js'></script>
</div>
</html>
- refresh.js:数据获取脚本
var stock = {
format_number: function(s, n) {
n = n > 0 && n <= 20 ? n : 2;
s = parseFloat((s + "").replace(/[^\d\.-]/g, "")).toFixed(n) + "";
var l = s.split(".")[0].split("").reverse(),
r = s.split(".")[1];
t = "";
for (i = 0; i < l.length; i++) {
t += l[i] + ((i + 1) % 3 == 0 && (i + 1) != l.length ? "," : "");
}
return t.split("").reverse().join("") + "." + r;
},
init: function() {
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4) {
var quoteStr = xmlhttp.responseText;
quoteStr = quoteStr
.replace(/var hq_str_s_sz/g, '')
.replace(/var hq_str_s_sh/g, '')
.replace(/=/g, ',')
.replace(/"/g, '')
.replace(/\n/g, '')
.replace(/\r\n/g, '');
quoteStr = quoteStr.substr(0, quoteStr.length - 1);
var quotes = quoteStr.split(';');
for (var i = 0; i < quotes.length; i++) {
var quote = quotes[i].split(',');
var code = quote[0]; //代码
var price = parseFloat(quote[2]); //价格
var pct = quote[4]; //百分比
console.log(quote[4] + ',' + pct);
var tr = document.getElementById(quote[0]);
tr.children[1].innerText = stock.format_number(price, 3);
if (pct < 0) {
tr.setAttribute('class', 'tr-green');
tr.children[2].innerText = quote[4] + '%';
} else {
tr.setAttribute('class', 'tr-red');
tr.children[2].innerText = '+' + quote[4] + '%';
}
}
}
}
xmlhttp.open("GET", "http://hq.sinajs.cn/rn=1522216317579&list=s_sh510300,s_sh601288,s_sz000157", true);
xmlhttp.send();
}
};
window.onload = function() {
stock.init();
}
在扩展程序里加载已解压的扩展程序即可使用,想打包什么的自行百度~
Chrome 行情抓取插件的更多相关文章
- Web自动化框架LazyUI使用手册(3)--单个xpath抓取插件详解(selenium元素抓取,有此插件,便再无所求!)
概述 前面的一篇博文粗略介绍了基于lazyUI的第一个demo,本文将详细描述此工具的设计和使用. 元素获取插件:LazyUI Elements Extractor,作为Chrome插件,用于抓取页面 ...
- Java 实现 HttpClients+jsoup,Jsoup,htmlunit,Headless Chrome 爬虫抓取数据
最近整理一下手头上搞过的一些爬虫,有HttpClients+jsoup,Jsoup,htmlunit,HeadlessChrome 一,HttpClients+jsoup,这是第一代比较low,很快就 ...
- Web UI 自动化单个xpath抓取插件详解
原文地址http://blog.csdn.net/kaka1121/article/details/51878346 单个控件获取 需求: 右键到某个控件上,就能获取到至多三个可以唯一定位该元素的相对 ...
- Chrome + Python 抓取动态网页内容
用Python实现常规的静态网页抓取时,往往是用urllib2来获取整个HTML页面,然后从HTML文件中逐字查找对应的关键字.如下所示: import urllib2 url="http: ...
- 玩爽了!直接在Chrome里抓取数据
一个小测试发现可以自动做题,于是想通过脚本的方式看能不能获取相应的题库,刚好可以学习一下JS异步操作.花了一天时间,总算跑顺利了,遇到了不少坑.记录下来分享. 1.JS如何顺序执行 JS有强大的异步操 ...
- 直接在Chrome里抓取数据
一个小测试发现可以自动做题,于是想通过脚本的方式看能不能获取相应的题库,刚好可以学习一下JS异步操作.花了一天时间,总算跑顺利了,遇到了不少坑.记录下来分享. 1.JS如何顺序执行 JS有强大的异步操 ...
- python 多线程抓取动态数据
利用多线程动态抓取数据,网上也有不少教程,但发现过于繁杂,就不能精简再精简?! 不多解释,直接上代码,基本上还是很好懂的. #!/usr/bin/env python # coding=utf-8 i ...
- EasyNVR网页摄像机无插件H5、谷歌Chrome直播方案之使用RTSP流判断摄像机设备是否在线以及快照抓取
背景分析 熟知EasyNVR产品的小伙伴都知道,通过纯Web化的交互方式,只要配置出摄像机的IP.端口.用户名.密码等信息,就可以将地址进行通道配置完成,即可将设备接入.如果设备支持Onvif协议,E ...
- fiddler无法抓取chrome解决方法
前端开发中,不可避免的要和服务器端进行联调,少了fiddler这个利器可不行. 由于无线开发需要配置UA,我使用chrome进行访问,但是今儿一早过来,发现fiddler无法抓取chrome的请求了. ...
随机推荐
- 查看SqlServer连接所使用的端口号
最近一个项目里用到了一个插件,在配置时发现连接数据库使用的是JDBC,输入URL时用到了端口号.印象中在使用Sqlserver时貌似没有提到端口号,在网上查阅了一下,记录下来省的忘了 方法是通过内置的 ...
- 能够附加图片的标签控件iOS项目源码
这个源码案例是能够附加图片的标签控件,源码JTImageLabel,JTImageLabel能够附加图片的标签Label控件,图片可以随意更换.位置也能够很好的控制.效果图: <ignore_j ...
- HDU_1850_nim游戏
Being a Good Boy in Spring Festival Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32 ...
- 招银网络面试题、考点、知识点总结(Java岗)
java基础 全是基础不用多说肯定考的多,尤其是招银 OOP特性/java语言特性:封装.继承.多态 多态具体的表现:多态应用举例.如何调用父类方法(super).重写和重载(重写父类方法的规则.构造 ...
- 修复Thinkphp框架5.0和5.1版本的远程代码执行安全漏洞
由于框架对控制器名没有进行足够的检测会导致在没有开启强制路由的情况下可能的getshell漏洞.最直接的影响为index.php直接被篡改成首页html的内容! 5.0版本 thinkphp/libr ...
- C#第三节课(1)
数据类型 using System;using System.Collections.Generic;using System.Linq;using System.Text;using System. ...
- vue.js层叠轮播
最近写公司项目有涉及到轮播banner,一般的ui框架无法满足产品需求:所以自己写了一个层叠式轮播组件:现在分享给大家: 主要技术栈是vue.js ;javascript;jquery:确定实现思路因 ...
- Oralce导入数据库出现某一列的值太大
这是由于导出的文件所运行的Oracle,和导入所运行的Oracle机器字符集不相同导致的,在UTF-8中有的汉字占三个字节, 并不是所有的都占两个字节,
- MySql数据库的一些基本操作---------------SQL语法
MySql数据库是比较常用的关系型数据库,操作用的是sql语句,下面来说一说MySql的一些基本操作 MySql数据库是一种C/S型的模式,即客户端/服务器端,对应到具体应用上,便是bin目录下的my ...
- BeanUtils.copyProperties()错误使用,给自己挖了坑
场景:需要对某个集合中的所有元素拷贝到另一个集合中,想着BeanUtils.copyProperties()可以深拷贝对象,误以为也可以拷贝集合,于是乎写下了如下代码 List<CostRule ...