实时抓取基金的估值数据

在天天基金上抓取实时估值数据

url:http://fundgz.1234567.com.cn/js/519674.js?rt=1589463125600

其中:519674为基金的代码,改成你需要的基金代码就可以了。
以下是返回的数据

jsonpgz({“fundcode”:“519674”,“name”:“閾舵渤鍒涙柊鎴愰暱娣峰悎”,“jzrq”:“2020-05-13”,“dwjz”:“5.4409”,“gsz”:“5.4543”,“gszzl”:“0.25”,“gztime”:“2020-05-14 15:00”});

其中的乱码是因为返回的字符串编码是ISO-8859-1,转换成UTF-8就可以正常显示
以下是Android端的解析代码,使用了Volley访问框架:

 	private void parseFundGSZData() {

        String url = "http://fundgz.1234567.com.cn/js/519674.js?rt=1589463125600";
        RequestQueue queue = Volley.newRequestQueue(this);
        StringRequest request = new StringRequest(url, new Response.Listener<String>() {
            @Override
            public void onResponse(String response) {
                String str = new String(response.getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
                handleGSJZData(str);
            }
        }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {

            }
        });
        queue.add(request);
    }

	//处理估算净值
	private void handleGSJZData(String data) {

        int start = data.indexOf("(");
        int end = data.indexOf(")");
        if (start < end && start > 0) {
            String jsonData = data.substring(start + 1, end);
            JSONObject jsonObject = JSONObject.parseObject(jsonData);

            String stringBuilder = "代号:" +
                    jsonObject.getString("fundcode") +
                    "\n" +
                    "名称:" +
                    jsonObject.getString("name") +
                    "\n" +
                    "净值日期:" +
                    jsonObject.getString("jzrq") +
                    "\n" +
                    "单位净值:" +
                    jsonObject.getString("dwjz") +
                    "\n" +
                    "估算净值:" +
                    jsonObject.getString("gsz") +
                    "\n" +
                    "估算增长率:" +
                    jsonObject.getString("gszzl") +
                    "\n" +
                    "估值时间:" +
                    jsonObject.getString("gztime") +
                    "\n";
            textView2.setText(stringBuilder);
        }

结果:

  • 8
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
你可以使用PyQt5中的QTableWidget来实现实时显示抓取的表格数据。 首先,你需要创建一个QTableWidget对象,并设置它的列数和行数。然后,在你抓取数据后,你可以使用setItem()方法将数据插入到表格中。最后,你可以使用show()方法显示表格。 以下是一个示例代码,它可以从一个CSV文件中读取数据实时显示到表格中: ```python import sys import csv from PyQt5.QtWidgets import QApplication, QWidget, QTableWidget, QTableWidgetItem, QVBoxLayout class App(QWidget): def __init__(self): super().__init__() self.title = '实时表格' self.left = 0 self.top = 0 self.width = 300 self.height = 200 self.initUI() def initUI(self): self.setWindowTitle(self.title) self.setGeometry(self.left, self.top, self.width, self.height) # 创建表格和布局 self.tableWidget = QTableWidget() self.tableWidget.setColumnCount(3) self.tableWidget.setHorizontalHeaderLabels(['姓名', '年龄', '性别']) self.layout = QVBoxLayout() self.layout.addWidget(self.tableWidget) self.setLayout(self.layout) # 读取CSV数据,并实时显示到表格中 with open('data.csv') as csvfile: reader = csv.reader(csvfile) for i, row in enumerate(reader): self.tableWidget.setRowCount(i+1) for j, col in enumerate(row): item = QTableWidgetItem(col) self.tableWidget.setItem(i, j, item) self.show() if __name__ == '__main__': app = QApplication(sys.argv) ex = App() sys.exit(app.exec_()) ``` 在这个示例中,我们创建了一个QTableWidget对象,并设置了列数和行数。然后,我们使用CSV模块读取了一个CSV文件,并将数据实时显示到表格中。最后,我们使用show()方法显示表格。 你可以根据你的需求修改代码,并将它应用到你的项目中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值