创建widget

简介:

1. 定义方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
def predictAll(tickers, startdt= '36' , enddt =  'today' , predictdays =  1 ):
     if  enddt ==  'today' :
         enddt = datetime.date.today().strftime( '%Y-%m-%d' )
     
     if  len(startdt) <  4 :
         startdt = (datetime.date.today() - datetime.timedelta( int (startdt) *  365  12 )).isoformat()
     
     result = []
     
     for  ticker in tickers:
         try :
             df = sdk.getHist([ticker], startdt, enddt) #.query( "isopen==1" )
#             print df
         except:
             msg =  'ticker '  + ticker
#             print msg
         else :
             dfochl = df[[ 'open' , 'close' , 'high' , 'low' ]].as_matrix()
             x = dfochl[:-predictdays]
 
             dfh = df[[ 'high' ]].as_matrix()
             yh = dfh[predictdays :]
 
             dfl = df[[ 'low' ]].as_matrix()
             yl = dfl[predictdays :]
 
             dfo = df[[ 'open' ]].as_matrix()
             yo = dfo[predictdays :]
 
             dfc = df[[ 'close' ]].as_matrix()
             yc = dfc[predictdays :]
 
             x2 = dfochl[-predictdays:]
 
             mh = LinearRegression()
             mh.fit(x, yh)
             yh2 = mh.predict(x2)
 
             ml = LinearRegression()
             ml.fit(x, yl)
             yl2 = ml.predict(x2)
 
             mo = LinearRegression()
             mo.fit(x, yo)
             yo2 = mo.predict(x2)
 
             mc = LinearRegression()
             mc.fit(x, yc)
             yc2 = mc.predict(x2)
 
             name = df[ 'sec_short_name' ][ 0 ]
             i =  0
             while  i < predictdays:
                 ret = {
                     'Day' 'Day '  + str(i +  1 ),
                     'Ticker' : ticker,
                     'Name' : name,
                     'High' : str(round(yh2[i], 2 )),
                     'Low' : str(round(yl2[i], 2 )),
                     'Open' : str(round(yo2[i], 2 )),
                     'Close' : str(round(yc2[i], 2 ))
                 }
 
                 result.append(ret)
 
                 i +=  1
         
     return  result

 

2. 定义接口

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# GET /sensitop/api/v1/analyzers/regression
 
import  RegessionAnalyzer as regession
import  logging
 
# REQUEST = json.dumps({
#         'path'  : {},
#         'args'  : { 'tickers' :[ '000078,600048' ],  'startdt' :[ '2016-01-01' ],  'enddt' :[ '2016-12-30' ],
#                  'predictdays' :[ '2' ]}
#    })
 
def __0014__(request):
     
     logging.warning(request)
     tickers = getFirstParam(request,  "tickers" ).strip().split( ',' )
     startdt = getFirstParam(request,  "startdt" )
     enddt = getFirstParam(request,  "enddt" )
     enddt = __notFuture__(enddt)
     predictdays = getFirstParam(request,  "predictdays" )
#     print tickers
     return  json.dumps(regession.predictAll(tickers, startdt, enddt,  int (predictdays)))
 
print __0014__(json.loads(REQUEST))

 

3. 定义widget接口

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# GET /sensitop/widgets/predict
 
uid = __getUId__()
template = open(__templateRootPath__ +  "predict.html" )
try :
     html = template.read().format(endpoint =  "waima.imwork.net:16301" ,
            tickers =  "__tickers__%s"  %uid,
            startdt =  '__startdt__%s'  %uid,
            enddt =  '__enddt__%s'  %uid,
            predictdays =  '__predictdays__%s'  %uid,
            btnSubmit =  "__btnSubmit__%s"  %uid,
            id =  "__id__%s"  %uid,
            btnHideOptions =  "__btnHideOptions__%s"  %uid,
            pnlOptions =  "__pnlOptions__%s"  %uid,
            dt_basic =  "__dt_basic__%s"  %uid,
            results =  "__results__%s"  %uid
           )
     print html
finally :
     template.close()

 

 

4. 定义widget页面

1
2
<!-- widget-start -->
<!--  new  widget -->
 

行情走势预测

  使用说明

行情走势预测,输入股票代码,系统会根据回归算法对该股票走势进行预测。

 1天 2天 3天 
结果说明:这里显示未来1-3天的各种预测值:开盘价、收盘价、最高价、最低价。
1
2
<!-- end widget -->
<!-- widget-end -->

本文转自疯吻IT博客园博客,原文链接:http://www.cnblogs.com/fengwenit/p/6204433.html,如需转载请自行联系原作者


相关文章
Flutter 有状态Widget 和 无状态Widget
Flutter 有状态Widget 和 无状态Widget
Android动态添加view设置view大小(宽高)
Android动态添加view设置view大小(宽高)
188 0
使用 AspectRatio Widget
使用 AspectRatio Widget
114 0
使用 AspectRatio Widget
【布局 widget】ConstrainedBox 与 UnconstrainedBox
【布局 widget】ConstrainedBox 与 UnconstrainedBox
146 0
【布局 widget】ConstrainedBox 与 UnconstrainedBox
【布局 widget】OverflowBox 与 SizedOverflowBox
【布局 widget】OverflowBox 与 SizedOverflowBox
147 0
【布局 widget】OverflowBox 与 SizedOverflowBox
【绘制 widget】Flutter CustomPaint
【绘制 widget】Flutter CustomPaint
137 0
【绘制 widget】Flutter CustomPaint
【Android】5.0RecyclerView列表组件
RecyclerView是Android推出的列表组件,例如QQ的消息列表,备忘录的条目列表等等都是可以使用RecyclerView来实现
301 0
Android 动态添加View 并设置id
Android 动态添加View 并设置id
607 0
Android 动态添加View 并设置id
Flutter一切皆widget但是不要将所有东西放入一个widget
当我们在widgets目录中,我们可以看到很多小部件,如Padding,Align,SizedBox,等。我们通过组合它们来创建其他小部件,我发现这种方法可扩展、强大且易于理解。 但是当我阅读 一些我在互联网上找到的或由新采用者编写的源代码时,有一件让我震惊的事情:拥有大量build ` 方法的趋势,实例化很多小部件!我发现这很难阅读、理解和维护。
101 0
【Flutter】StatefulWidget 组件 ( 创建 StatefulWidget 组件 | MaterialApp 组件 | Scaffold 组件 )(一)
【Flutter】StatefulWidget 组件 ( 创建 StatefulWidget 组件 | MaterialApp 组件 | Scaffold 组件 )(一)
194 0
【Flutter】StatefulWidget 组件 ( 创建 StatefulWidget 组件 | MaterialApp 组件 | Scaffold 组件 )(一)