当前位置:Gxlcms > 数据库问题 > Mysql0.py

Mysql0.py

时间:2021-07-01 10:21:17 帮助过:2人阅读

# -*- coding: utf-8 -*-
import sqlalchemy
import tushare
import pandas
import socket
import struct


class Mysql0:

    def __init__(self, user0=test, password0=123456, dsn0=odbcdsn, host0=192.168.1.3, port0=12345):
        self.user0 = user0
        self.password0 = password0
        self.dsn0 = dsn0
        self.engine0 = sqlalchemy.create_engine(mysql+pyodbc://+self.user0+:+self.password0+@+self.dsn0)
        self.host0 = host0
        self.port0 = port0

    def get_url_data0(self):
        codelist0 = pandas.DataFrame((tushare.get_today_all())[code])
        codelist0 = codelist0.sort(columns=code, ascending=True)
        codelist0[index] = pandas.DataFrame([i for i in range(0, len(codelist0))], codelist0.index)
        codelist0.to_sql(codelist, self.engine0, if_exists=replace, index=True, index_label=index)
        for i in range(0, len(codelist0)):
            stockdata0 = tushare.get_h_data(codelist0[code][i])
            stockdata0[date] = pandas.Series(stockdata0.index, stockdata0.index)
            stockdata0 = stockdata0.sort_values(by=date, ascending=True)
            stockdata0[index] = pandas.DataFrame([i for i in range(0, len(stockdata0))], stockdata0.index)
            stockdata0.to_sql(codelist0[code][i], self.engine0, if_exists=replace, index=True, index_label=index)

    def get_sql_data0(self, code0=sh):
        stockdata1 = pandas.read_sql_table(code0, self.engine0)
        return code0, stockdata1

    def run_socket_server0(self):
        socket0 = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        socket0.bind((self.host0, self.port0))
        socket0.listen(5)
        code1, stockdata2 = self.get_sql_data0()
        i0 = stockdata2[index]
        o0 = stockdata2[open]
        h0 = stockdata2[high]
        l0 = stockdata2[low]
        c0 = stockdata2[close]
        v0 = stockdata2[volume]
        i = 0
        while True:
            connection0, address0 = socket0.accept()
            if connection0.recv(1024) == bconnect and i < len(i0):
                connection0.send(struct.pack(6si5f, code1.encode(utf-8), i0[i], o0[i], h0[i], l0[i], c0[i], v0[i]))
                i += 1
            else:
                connection0.close()
                socket0.close()

    def run_socket_client0(self, message0=bconnect):
        socket1 = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        socket1.connect((self.host0, self.port0))
        socket1.send(message0)
        code2, i1, i1, h1, l1, c1, v1 = struct.unpack(6si5f, socket1.recv(1024)[:32])
        socket1.close()
        return code2.decode(utf-8), i1, i1, h1, l1, c1, v1
# py2.py
import sys
sys.path.append(D:\360data\MyWorkSpace1)
import py1
Py1 = py1.Mysql0()
Py1.get_url_data0()
print(finished!)

Mysql0.py

标签:

人气教程排行