爱吱声

标题: 一个用stata 计算股票成本的小程序 [打印本页]

作者: awer    时间: 2011-8-13 18:03
标题: 一个用stata 计算股票成本的小程序
本帖最后由 awer 于 2011-8-13 20:49 编辑 5 u: n, b8 ^: Q# `6 f: m5 O
/ @3 i% p  f3 `; ~
   我是从西西河一直追虎大追到爱坛来的,虎大曾用stata 分析过股票的长期成本和一年的短期成本,但是直接用kdensity命令无法得出筹码峰的具体数值,因此我写了一个小程序来计算股票的筹码峰值、长期平均成本和短期平均成本。下面就给出具体实现方法。
计算之前需要有
1 招商证券系统(通达信其它客户端也行,功能都差不多)
2 Stata软件 (我用的版本是Stata/SE 11.0
然后
1.新建一个文件夹储存股票数据,比如:
e:\stock\source
2. 股票数据导出
a 进入招商证券, 系统-盘后数据下载,更新数据
b快捷键“34”进行数据导出, 在弹出窗口选择; }  c# Q# M3 v5 ]# D+ ?
高级导出”,
在高级导出窗口选择日线导出”,
将导出目录选择为你新建的储存股票数据文件夹的目录(e:\stock\source! 切记切记
文件名 XXXXXX.TXT
勾选  数据精确复权
添加品种中选择想要导出的品种
开始导出
3下载 stata, 将本贴附件中的hello. do文件copystata根目录下
Stata中的 Do file editor 打开hello.do 文件, 确保hello.do 文件中 e:\stock\source 和你保存股票数据的文件夹目录一致
现在就可以计算了,以露天煤业(002128)为例
Stata 输入如下命令
do hello
hello 002128- @/ w6 D1 Q" q/ m+ e. F7 i5 t

# S  \: ]3 K& Q" G(002128
为你想查询的任意一只股票的代码)
几秒钟之后应该会出现下面一张图
- `1 W0 R3 P, r$ K6 ^7 Y
hello.do (5.25 KB, 下载次数: 13209) 其中蓝线为股票上市交易以来的平均成本值(注意!此值没有去掉一级市场发行和国家的0成本)
红线为一年内交易的平均成本值
黑实线和虚线为一年平均成本值附近两个筹码峰的值
黑方框代表的事20内每天股票的收盘价格
红方框代表股票最新收盘价
山寨完毕, 收工!!

作者: 明月回春    时间: 2011-8-13 20:17
本帖最后由 明月回春 于 2011-8-13 20:19 编辑 ' `/ e4 i4 E2 ^
) [0 V$ s5 Y  l0 d9 `) @  e, f
程序写的不错./ l3 ]* U/ u8 W8 p7 [  b
不过有一点要注意.通达信导出的数据,只对价格复权,并没有对成交量复权.所以数据需要手工处理.虎大买的是Thomas One Bank.$ B. n; A  s4 \1 v4 f. ]6 Z% I) ~
还有就是虎大除了用了kde,还有摘要功能,你可以看看这个也是山寨
3 V. v5 O4 q( n3 Y9 Z, z8 I, O  |- f! _# r. T! m9 V

作者: awer    时间: 2011-8-13 20:20
这点我也注意到了,所以我用 成交额/复权后的价格  作为成交量 用于权重计算
作者: wenty    时间: 2011-10-19 14:32
多谢,挺好用的。0 G% o. O- G1 v) t0 N
通达信似乎无成交额一栏。导出的txt文件要删掉header,否则stata当数据为string了。! }! o+ a2 W: _0 z4 t* J

作者: 旅途愉快    时间: 2011-10-19 15:40
本帖最后由 旅途愉快 于 2011-10-19 17:44 编辑
' B1 E& p  p6 _5 @9 m& X) F0 R8 t" C3 q9 C8 E) q
没太看懂。。。$ U0 J3 w$ v# q/ E7 E2 c

* `4 t0 M$ u: b1 e7 y7 _露天煤业最近20天的收盘价在20块左右?
作者: 旅途愉快    时间: 2011-10-19 17:47
仔细看了看,发现原来自己理解错了~:)' v1 T' t$ J, H( L# g! N
& J' A/ K# x$ t$ D/ I; w# O
谢谢awer。有问题再请教哈~~
作者: 旅途愉快    时间: 2011-10-19 18:09
还貌似有一个问题啊,为什么我处理2000年以前上市的股票,都会出现:

  1. , x6 i3 B4 |; g& Q3 B2 K  p
  2. hello 000425& F+ h( S' u  s  t4 b7 G- N3 X
  3. time variable takes on negative values; B" y( V; `+ D/ j
  4. r(459);
    $ X' W" f3 M3 B

  5. / C/ ^: J7 p# h% M/ S. @6 v
  6. , y( i0 ?2 J* i( F) w
  7. . hello 000783% ~. K, m) n2 S- |7 q2 I$ ]
  8. time variable takes on negative values% M9 v0 [8 h' n& c
  9. r(459);5 |9 |  |, o' r, N6 o; E3 j
复制代码
2000年之后的没问题,比如露天煤业。
作者: 冷眼看世界    时间: 2011-10-19 19:25
不错,我也来试用一下
作者: 沉默的前哨    时间: 2011-10-19 20:45
为什么老是提示:type mismatch
作者: 沉默的前哨    时间: 2011-10-19 20:49
能不能帮忙看看:. s/ n* x8 r  d# ^  I; b9 n
8 |  n# e# s$ l! y; L
do hello6 e$ @3 H" L5 l, v6 J
$ D! N- S+ M! q8 I  ~" C/ m
. ! R* T! E0 O; y9 F; f3 v! ?
. capture program drop hello
: D# W# j1 R9 ^$ }  W
" a# F! a# {4 f: L. , T2 k5 p: X: [$ s8 v- w! }
. set mem 1024m
4 \% T0 w! e6 M! s' h- E- E/ dno; data in memory would be lost1 ~, b2 ]- h2 O. {8 R7 {
r(4);3 {9 b/ X% b2 I6 X  }  E/ r" E, }

4 X" T0 F0 [- R( rend of do-file
4 p( A( s( y# |
( C* Y" u4 z: P7 Q0 x- K; Q8 c1 i7 mr(4);: i1 [9 f  {. F- D3 B% f

/ n% o2 Y3 x: Z& D. `. hello 600063. A( V$ D0 |  C; @: D
unrecognized command:  hello! d1 I1 z# J5 u, M
r(199);4 ]9 f! O% E2 |

作者: awer    时间: 2011-10-19 22:03
沉默的前哨 发表于 2011-10-19 20:49 3 M3 a" m1 q& a
能不能帮忙看看:* Q  s2 P3 O* s% a, [

! J* Q, J0 {. _, g" l$ w: f, ] do hello
* l( A8 S% l$ X6 A# ?
你算得哪个股票?
作者: 阿雷    时间: 2011-10-20 08:52
awer 发表于 2011-10-19 22:03 ! h1 O, v9 x0 w: w- z1 k
你算得哪个股票?

" M( {4 R/ V- T5 |3 X那现在露天煤业可是在平均成本以下啊
作者: 沉默的前哨    时间: 2011-10-20 10:30
awer 发表于 2011-10-19 22:03 ) a* p& _4 ^/ H, n7 K
你算得哪个股票?
* Z) z% V& l$ E
我是用通达信引出的数据,比如600663,在e:\stock\source 里的文件是以SH600663.txt存在,无法执行,后改成600663.txt还是不行,请指正!
作者: 沉默的前哨    时间: 2011-10-20 10:32
awer 发表于 2011-10-19 22:03 " G8 I* u: b# b" W; Y# V/ N7 w
你算得哪个股票?
( _# D6 U% a) w( w' u
do hello 后变成
: H; y* X( \4 e' f; l......! Z% [( g4 ^6 B5 H+ v5 G+ h

. I, y' L' `3 h3 h9 I+ mend, j, }+ ?( @3 X& M
: {4 `2 J% K3 c/ J
. & Y# l8 x+ ]# H% {; \( k4 U
end of do-file
# M2 v' k4 w- T9 I9 z* @* a
作者: awer    时间: 2011-10-20 11:18
沉默的前哨 发表于 2011-10-20 10:32 . c" p- _% r+ E2 z9 w- o, u
do hello 后变成
- f4 o( b7 u" }9 I2 q......
5 i2 k7 P$ S; W$ B! _

作者: awer    时间: 2011-10-20 13:32
沉默的前哨 发表于 2011-10-19 20:45 ( U' o: X6 q( A0 _; @, Z
为什么老是提示:type mismatch

3 w' q4 W: y. z  ]5 K/ a注意 日期格式要选成  yyyy/mm/dd,要不然时间变量格式不对
作者: wenty    时间: 2011-10-20 14:16
"此值没有去掉一级市场发行和国家的0成本" 是指已包括一级市场发行和国家的0成本吗?$ X# y5 }- Z7 w' h
谢谢. K4 Z: J" J" k0 F1 W

作者: 琴心三叠    时间: 2011-10-20 17:35
下方的棕色曲线是代表什么的
作者: 琴心三叠    时间: 2011-10-20 17:35
下方的棕色曲线是代表什么的
作者: maqiangcn    时间: 2011-10-20 19:13
明月回春 发表于 2011-8-13 20:17 ' l3 v' B$ v) z" A2 a) k% |
程序写的不错.$ W7 `" C$ X, v0 d
不过有一点要注意.通达信导出的数据,只对价格复权,并没有对成交量复权.所以数据需要手工处理 ...

8 G, G" C# M6 B+ g4 Y8 c& ^你好,这个链接好像不对,能确认一下吗?
作者: 琴心三叠    时间: 2011-10-20 20:03
琴心三叠 发表于 2011-10-20 17:35
/ F. N7 P6 L( R下方的棕色曲线是代表什么的
7 Q8 Y: J% @- h, o  Z! \" S' F; @
两条曲线只是周期的不同吗
作者: 琴心三叠    时间: 2011-10-20 21:37
谢谢答复  还有一个问题  我导出的文件为何只有当天的数据  而不是历史全部数据呢
作者: 偶然    时间: 2011-10-20 22:19
建议楼主给个数据格式模板
作者: awer    时间: 2011-10-21 10:05
琴心三叠 发表于 2011-10-20 21:37
/ n5 z. O, V) B$ d' n4 l谢谢答复  还有一个问题  我导出的文件为何只有当天的数据  而不是历史全部数据呢 ...
$ W' S% Y1 F! }1 p4 F( q% E8 V
有很多问题是数据不全造成的
: d* c1 X" k( t1 T1 d$ Z* S* I如果想要全部数据,- i$ `6 Y  V% L3 N% v$ Y+ M% n
系统--盘后数据下载--日线数据--日线和实时行情数据
7 L" e2 K% k! r* L* S" P1 @; ?+ x! r+ s/ b
把开始时间设成中国股市开盘的那天,下载全部数据1 I/ q, z6 U  q( z' {

. ~5 O4 c! ^7 T1 r  A% S下载完全部数据后,在屏幕上使用快捷键 348 X) w% f: N0 S# Z5 y5 p7 ?

( C6 I: ^* ~9 h3 f' v4 [( I5 {. `34--高级导出--
* T* W- y; ?4 n; c. |
' {+ b, ?, C0 C然后选中   日线导出;选定导出目录;文件名设为:XXXXXX.TXT;勾选精确复权;不要生成导出头部;分隔格式为tab();日期格式为YYYMMDD,然后选择添加品种: B, f0 u0 a2 l" x4 t4 l1 {! K  v

6 D# }) ~. a" p2 m; |  F( e/ y我一般都是把所有数据下载到指定目录下,然后进行hello运算
% S% ]4 r3 R7 y  d+ m' g. {. r5 y! n1 t( H- g" B) l

作者: 沉默的前哨    时间: 2011-10-21 12:40
awer 发表于 2011-10-20 11:18

3 A+ @3 d3 v- \1 N7 J谢了!我自己还是没搞定,我再看看。
作者: 沉默的前哨    时间: 2011-10-22 12:31
搞定了,谢谢!
作者: warbrai    时间: 2011-10-22 16:38
沉默的前哨 发表于 2011-10-21 12:40
/ C' b$ V; I( D) b0 l; X: Z7 _1 ^谢了!我自己还是没搞定,我再看看。
1 [% F  f4 V2 l+ t3 \+ C; G. z
别选择 "导出数据头部"
作者: 沉默的前哨    时间: 2011-10-22 23:16
warbrai 发表于 2011-10-22 16:38 $ Z1 g, E' A% ~$ {$ G
别选择 "导出数据头部"
  `* g" z4 x1 [
是的,谢谢了!现在可以了!
作者: 心静天地宽    时间: 2011-10-23 20:45
老早就想找个这样的软件和方法了,无奈见识有限,一直没有办法,感谢你的无私。
作者: 琴心三叠    时间: 2011-10-23 22:04
抱歉  我还是没明白棕色曲线的意思   黑色线代表筹码分布密度  那棕色线你说代表随价格的变化率   这我不太明白  请说详细些  不好意思  我比较愚钝
作者: 琴心三叠    时间: 2011-10-24 18:45
hello 600085
" [0 R5 k  N  [$ o& [, iunable to change to E:\fenxi
5 ]% F5 p  @# `这是什么意思?
作者: 观风望月    时间: 2011-10-24 20:32
已经下载下来用了,非常感谢热心的分享。
: ^5 K( G" r. L/ ~因为不会使用stata,所以有个小问题想请教一下,我按照你教导的方法已经成功测试了露天煤业,兴业银行等几个股票,都成功出图,但是在计算600188.601999的时候,程序提示“
/ r1 q! s) p) Y2 v& K. hello 601999
- {# g2 P, O: |statement out of context
1 M, }. M9 D( Y8 g1 b+ \. gr(119);) n( o+ g$ m3 @2 f) n
: H! S: s$ E6 m" x* C' [+ d
我查了一下Help的内容,对于这个错误也没有特别具体的解释,不知道是什么原因造成的,因为数据的导出和格式和前面几个股票都是一样的,所以我搞不太清楚到底是怎么回事。2 c7 s+ ?1 N; I( {0 d' w( _) j3 W/ \

# P# y& A+ b, m! ^$ l- k另外,虎大提到过的国家成本和一级市场成本加权可以通过在数据中添加一行交易数据来实现,只不过这笔交易的成交价格和成交量需要自己加权计算,对于不分红的股票来说加权计算还是比较容易实现的
作者: 本拉风    时间: 2011-10-25 15:22
横纵坐标分别表示什么,2条曲线又表示什么
作者: 钱潮滚滚    时间: 2011-10-25 16:08
发个图验证一下和大伙的结果有没有出入.
- {5 m" u) A7 Q/ d5 I: r$ s! m' R& S$ Q4 p4 O3 P9 N
收盘价到昨天为止的三一重工:
% S: |2 {. x# Q+ }6 `2 i5 {# S2 A; w4 k3 E0 p

& v5 F3 N1 ~7 R$ z, G7 @" X; {( ?1 k, A( Z& d

作者: kevenjames    时间: 2011-10-26 14:05
就楼上这个图,几条线,还有黑点分别都是什么含义啊?
作者: wenty    时间: 2011-10-27 04:17
总结一下使用心得& {0 _( l8 {& B7 R% ~
1)删掉set memory那一行
4 Q2 K4 x- d; o2)改路径% J7 {# P* K( q5 o
3)从软件导出数据时,要先下载,后导出,不选导出头部。3 T! K; a# g( X3 @
4)用notepad看导出的数据每列对齐没,用tab修正。
! w8 [+ n6 `1 O0 F希望有帮助。
作者: 沉默的前哨    时间: 2011-10-27 09:09
老祖爱蓝军 发表于 2011-10-26 22:50
, S1 n) a6 N- F% c2 k  [. `9 @我出现同样问题,请问怎么搞定的?
, p& c. m! [3 @0 i# ^# a
关键点:
. }4 f( a0 r8 i8 m$ D1、文件名设为:XXXXXX.TXT;
$ [4 n: c* i* S: h# i6 U+ G, p, X2、勾选精确复权;7 F5 k+ ^! c. C$ G# \
3、不要生成导出头部;7 V" S# }: ]* E9 g3 X
4、日期格式为YYYMMDD;
& _; R( C/ n. q0 m5、如果不行,建议可以关闭stata再打开试试,我认为和操作系统的版本可能也有关;
作者: 范进中举    时间: 2011-11-8 16:10
不错,按照楼主操作完,最后是选择do命定,选hello文件,然后hello 代码就行。
. y7 M4 }  k+ ]' c& X: `( d0 \几个问题
) t5 r! D, I: f) \3 f6 S; O* @  W2 ~" o) q8 ?; r# W/ Q1 I
最边上的蓝色的4.473554是什么意思,红点13.84054是最近20天平均价?灰点15.3842,黄点19.09930是什么意思?
作者: 范进中举    时间: 2011-11-8 16:12
钱潮滚滚 发表于 2011-10-25 16:08 - b" {! a# Y% l7 c  C
发个图验证一下和大伙的结果有没有出入./ b6 [: m" X( x( a

3 ^8 M/ M6 z% G, M收盘价到昨天为止的三一重工:
4 P. T9 ^( v! D0 p0 v$ Z
蓝色线上的8.520041是啥?红点13.85195是啥?灰点15.40402是啥?黄点19.09793是啥?
作者: maodeng    时间: 2011-11-9 21:47
6 r8 v9 g$ `. j/ V

8 d  v- z" M7 i' s% S' m9 X大牛,小生这厢有礼了,啥也不懂,照着葫芦画瓢,我的数据应该是更新到11月9号的,图形如下,不知道对不对 % e. W# W: O! v- [
0 f: ]% C( ~' w) R+ I3 x' O
8 K' r3 ]  G5 h8 E

作者: maodeng    时间: 2011-11-10 19:58
wenty 发表于 2011-10-27 04:17 0 v' t+ ~( ^2 ?3 {8 p6 W
总结一下使用心得
) K" y6 w! Z# S5 N0 ^/ i1)删掉set memory那一行7 `# N) F+ ?4 `6 k
2)改路径
# \# t9 q$ y$ Q% {7 c. x' j
记事本打开后,怎么用tab
作者: 冰火    时间: 2011-11-10 22:44
认真学习
作者: higer    时间: 2011-12-9 22:34
我也曾尝试过使用stata软件对股票平均成本进行分析,但是作为一个非专业的炒股人员,而且日常还有工作的人而言,这种方法似乎显得太专业,而且操作难度极大,不一定实用。! L& C/ W; P. }9 d
- r1 P; c5 v; G. F2 Q* C4 k
使用这种专业的技术分析方法容易造成这么一种现象:大家都对导出的光滑漂亮的图像感觉良好,然而在股市中依然无法进退自如。
作者: jway315    时间: 2012-3-24 20:12
谢谢楼主,希望继续给同学们挖宝哈!
作者: awer    时间: 2012-3-28 18:06
改了一下,这次运算应该没啥问题了
5 A/ f3 |5 i' |/ k; p/ m! ~% n" ~" U) q% N* Q" }: D
8 }6 u% Q. T8 x3 n" f3 a" J
capture program drop hello3 {0 y7 y; Z8 {! G
! i% w! ?/ D. D. M! H; o
program hello+ N8 ^' ^/ \* e4 r7 d
& r/ J" M4 l% U
quietly {
' r0 l8 `* [9 ?( v
3 j: E0 X3 o! _0 d- ~clear- \( [  G1 d8 L( j' G2 W
( E4 i7 s9 D3 b  h  |. e
cd e:\finance\stock\20110101\source6 ^' A( @4 X/ r0 r9 W0 z- r. I/ z9 @
$ K6 Q. u$ b& g5 p
insheet using `1'.txt! |3 }0 p% S0 `" [8 L
( b: {) G, Z& n5 Q  A
   keep if v5>0) \, F$ ?  e/ X5 l) C
   
( X* f% |6 X) q! g/ z   gen vt=_n, ?( S' Z5 s' w' H% @6 n" J
   : L% }3 t/ A1 }
   tsset vt% y' s+ C8 K( J2 ]9 n$ Y% W
+ W9 H3 n7 R8 L/ I1 s5 w
   gen zf=D1.v57 b1 R* v3 ~- }/ w
1 [8 ^5 T' ~8 l7 i+ m3 U1 f
   gsort -v1/ ^( @/ j4 {8 ]0 D$ S% L8 q/ R7 W
2 l: i; V; [8 q( Y7 ^
   gen avol=v7/v5! d! d" ~0 X7 p+ f( q
   6 Z0 W" x' H* e- |5 S! b
   keep if avol>0- V* @% d( p, S' {* O
   5 Z9 t5 b" g5 h% n9 C6 |4 E
   drop vt# G+ B2 z% w& c' Q4 U2 ^" z
  
6 H6 P* }' O2 p   gen vt=_n
) X5 f* H" z! i+ f  b   & m: s. |/ O/ u' f( {
   tsset vt; m& L' K% M3 {' \' v5 ?2 T/ U( q
   - n) K( h$ Q- q' X9 j3 N
    sum v5 [aw =avol]
2 i2 Y  G5 v8 i! U9 N9 a. ~) m/ S) d# r( W9 q$ r3 T
   gen amean=r(mean) in 1
; p2 U- w, j( s' U, d: W7 J- a6 E6 z   
9 ^  u; b2 J# q/ m1 L( k+ d9 \- ?   * 总加权平均值 amean
. p, B' N7 L1 s7 }* m( |+ @3 s   
; t3 t8 k0 C+ ~# i4 G. ^& V1 I   
. V  }' t$ S: R1 l1 W0 O   keep in 1/240- G+ I3 t" ~" [. d
: k+ m+ E4 ~9 l. }/ I
   sum v5 [aw =avol]/ K0 w5 K1 ?; p" ?" `: Z

# O" Y! C! M5 @6 \/ v+ d0 i   gen mean240=r(mean) in 1" p' {4 d! B& T- L
   
7 [& \9 b/ P; P1 ]/ G5 d   *240加权平均值 mean240  Y; y  J: ~! R, \$ M. ^" y9 u
   
6 e# Z# l7 U0 L   set obs 500
# ?9 s/ A7 R0 ^" x; j   * Z; b; d, B. V$ k5 Q( [* w
   kdensity v5 [aw =avol],gaussian n(500) generate(dx240 dy240) nograph$ U5 b( A3 g/ d, ?7 V1 H& X! R
   
" A, ~) H9 M, n0 j- V' k3 f   *240 kdensity(dx240 dy240)
: ~, H" K% D( G9 f   0 j3 a+ D- B9 ?' z
   sum dy240
9 _# \  S4 q3 f   $ H# j; R3 b; ~7 ~, D, B0 {
   gen yxis=r(max) in 1
1 G8 V* ]+ T) e4 G7 S. a8 I3 x9 m   
7 N, R! Z7 W) K( ]8 [   gen yxis2=yxis/2
* R- I" `0 L! g( Y! ]7 \   
) s" A2 k! H4 `- w' z4 O   *yxis
6 O" j- F2 k% j9 m: m* r* h( |   9 M" s. l1 ?- \( |
   gen dy240max=r(max)
/ K0 z2 i! ~, {, G% [   
2 d$ X! n! [# c: H' S7 |7 v   gen dy240minp=r(min)
+ ~" ^# x2 t& F: l' w4 S7 d 5 `7 ?% Z& L. M" Z3 i: s7 ]
    gen vtt=_n
+ n7 y2 D7 ?4 s( b, `! I$ c& F
: u. c$ o! h$ k2 f  [2 V    tsset vtt- f; G* v  ?4 K! e7 ?! x
/ n; }4 j7 f- V5 v6 [( d
   gen ddy240=D1.dy240/D1.dx240
; G5 c5 X: X1 g   
7 C: ~7 v# V. |   sum ddy240
7 b' X  h( n7 p  C5 a   
0 O+ O' M+ X3 E9 y, ^: a; v   gen ddy240max=r(max)
8 }( a4 ^# q! O   ' a7 M7 l& G- C$ k; t) k2 b( t
   gen ddy240min=r(min)* E; m; F4 K' W2 B. E
     
* A1 `% Q* C7 f$ |: y9 Z   gen ddy240g=ddy240*(dy240max-dy240min)/(ddy240max-ddy240min)
1 R- M4 Y# i: F2 i   ; r* J# b2 N- O, [
   sum ddy240g
0 z8 _) M6 J# F" C' s& O   
9 a- V* T+ S4 @: v   gen yxis3=r(min) in 1
9 S3 r( ]  h" S& v   
. B- b* i4 ~- G! G+ B$ i3 `   gen yxis4=0 in 1
' u) O4 a' j$ Z1 a' \: W  8 F$ c9 e! V# Y9 h) P- ^* _
  *ddy240g 1 e0 Z: G$ [  d
   
+ ?, B5 L6 b- H6 @" I' U: Q   7 F6 @. ]% y# r4 X, n/ E" D
  preserve 3 ~! P1 F- F7 w" A: j! U4 s
  + @- k9 B& A4 V4 C( `7 F% X7 E
  sum v5 [aw =avol]% c, c! `9 x5 F, s/ p1 f
  2 p. k  S5 Q* X) T( `( \
  keep if dx240<r(mean)7 R; U- F% |, u  K
  
: X3 h/ l. s2 m8 ]" _* B- I# E7 v  sum ddy2409 j% H4 e0 J+ G/ c3 u
  ' j+ z5 H; a# T9 ^; C
  if r(min)<0 {1 g& [7 o6 t: @9 [1 G( ]4 e, {1 J
        
2 Y* `, k5 v. M: H& R8 S! H8 G                keep if ddy240<=0
& \  X3 g+ m0 U8 C. o                0 W, {$ ]4 S7 K  q- \( K- N" n+ q* d; C
                count# s- X3 L) p5 X
                8 R$ U7 z1 ^+ m! D* |7 ]
                if r(N)>2 {
0 W7 q5 J0 h" i7 ~5 Q                 ' Q3 r) G7 l# e# X
                 pkexamine dx240 dy240
# o+ V7 R' ^+ F2 C; m6 D" M1 o' _0 ~2 u                ; ?, z5 A* E' ?% {7 ?3 o
                local tempminp=r(tomc)8 r8 |4 D: A- p; X6 N3 O
                restore 8 p! r9 p2 {2 r4 v2 u: l
                 }
# m1 m  I$ @. t: q7 o                 1 P* [( ~0 X# c' w5 L1 U" z# Q
        else {
4 d; L4 F. o$ C2 a               
; Z: C1 t7 i5 D4 I8 f                 di "cannot find minp"
2 n' C: x0 F$ y                 8 w( t9 v; [0 f" H5 H
                restore . B9 |0 G4 w: P: E! w( m
                 sum dx240
( g0 d, f4 r1 r0 u                 local tempminp=r(mean)
* J, y  P" b' F  V                 9 Z# ]; D/ h" f- D7 R
                 }
9 R+ F9 T/ X6 g; [) Q                }9 |; F0 j$ @( Q
   else {
, F3 L' N. z0 o0 \! c) X4 a$ @                 
8 O1 f# I# [" G$ O  b* `9 P                 keep if ddy240<=r(min)
3 H9 o+ O& v  ?; w$ @                   S, N: R6 \  X; f9 y. B; R) [
                 sum dx240" V% z+ F6 q6 h, E
                 
! W$ ~- B6 D0 t& {7 o) b                 local tempminp=r(min)
& D0 X- m9 z# l4 B( l                 restore 0 Q- Y& M: p6 I- _& j. X$ p
                 }
8 B( n' c. _% a0 d4 C: N6 Z9 h7 U8 J* I- U
, Y/ T3 x3 W' R6 ?+ U" O# m9 Z; O
" S1 h2 Y$ o) ]7 t* d
   gen minp=`tempminp' in 11 t- F5 a( W; s4 h: U
   *240 minp* z1 \' {* s( B
  }: H( Y6 l6 s9 J6 z9 |( F( M
/ z  E4 ^, _0 m, \9 B* ?# h( W6 h+ G
   
/ z7 F+ b5 J6 c/ ^- F% c) T; p   preserve ) t$ B6 m- y& {4 n! a
   
8 N6 G( Y  x: q# h   sum v5 [aw =avol]
0 n  ]2 L6 b' T1 |1 ^" U   
4 a- t  f' k, X% g, X$ {5 Q- G   keep if dx240>r(mean)
9 }% F+ c4 N/ |$ q' V0 N- |  m. E   4 L4 S1 [- q( l; k7 l: N
   sum ddy2403 H! O3 Z  I& I* f7 R
   
2 f2 t1 ^+ r# `: \- {, H   if r(max)>0 {! Q4 V2 N0 n  r$ p" p3 g' g
               
' @% ]  U/ q0 N* ~! n1 c: M                keep if ddy240>=0! N8 K# ^* H" c; x/ B
                $ ~' L4 S+ @  L1 R: Q
                count8 B$ b. h9 W* ]' v; ^% a
               
# {! |# r, h( y( ~8 c& r                if r(N)>2 {. f/ O+ L. B! _& ~9 u
                 
# Q/ P3 p+ y$ U  K/ ^; [3 G( h                 pkexamine dx240 dy240
+ H) C( V, K, X* k; S1 h               
% ]' a: E1 G/ J$ L7 V+ m                local tempmaxp=r(tomc)
, d, f. I" v. y                restore ; q- S6 T+ M0 E# P5 q: |$ M
                 }1 V. j" Z7 Q7 b+ F! V1 h) ?0 `
                 
, @; K4 A) C" [3 F$ s) ?' K                 
; D& G. `0 {# Y, u& s9 d        else {
$ b0 J' |, F% p% E* r  g9 E( w$ k+ g                restore
, K' m+ A4 B2 }                 di "cannot find maxp"
/ p& n. B/ V+ \! e- L                - N8 ?4 ~  n& R5 _, I* C
               
, U( C) _- Q. |                 sum dx240' @& i# @' P# a9 \- y8 A3 ~5 A3 j" x
                 local tempmaxp=r(mean)
" |) h* `7 c$ x$ v                 
# ~/ S4 V. H* ]+ Y                 }
: x+ \. q) @- w                 
& {7 {2 w* l8 j' {1 K                 }, j3 j; }4 ?& O- Z5 {8 x7 ~! x
                 
5 R, E: g2 `+ g* Q& u# z2 Z    else {0 r% x$ s, z9 p9 H+ X/ @
        5 m* i  j% ^7 [7 e: [$ V
           keep if ddy240>=r(max)
2 l) P  p; \7 }7 o; h# y          
& Z  X' Z2 @  R# ~           sum dx240( ^( Q- d5 Y" [3 j* L& ^, L
          
/ P% t/ K( w" o. F           local tempmaxp=r(max) 0 r6 V) \$ n! q
           restore 1 _. ~. d/ b4 b1 I, ^
           }
8 M8 r/ n0 w7 u5 h8 o       
+ C8 _* Q6 p; y+ s; n, Q; P3 J. c5 }5 L* d
  + M3 K! `* ]) V2 u' [' U
2 Q6 Z* I& E9 y# z
   gen maxp=`tempmaxp' in 1
9 q  x1 s: h" f9 x& W2 }( F% m6 j   
% Y  P3 e3 L3 F  T; `   *240maxp
* `% t3 p0 g5 U* N   
2 f0 E! k; J; k& @6 s) F   $ S8 l! n' s" L7 [
   *-------------ddy240pminp左侧高峰值-----* \- k" {6 E. ?/ z( @
   ; _9 m- h+ r; q( l) P8 \! _1 W
    preserve
8 _* X# R# B. O  h   
) k- l& e( O0 G, \   keep if dx240<`tempminp'/ K& `" B) g2 b; U6 O
   
5 \/ K0 ~. T5 l' f4 v3 B) B   keep if ddy240>0
7 d7 @& X! B% S* C# i   $ r, }' i9 J3 F, ~. J/ b
   count& W0 T" v* B# [2 s- Q
                ; }: y! `4 [( v1 b
                if r(N)>2 {
( ^1 v7 A' Z  q0 B. h                 " T  u3 |9 b$ \
                pkexamine dx240 ddy240
3 a% k4 e' L1 k4 |' G3 G               
8 l+ S. N& L- A1 O1 I0 M/ j1 R1 Y                local tempminphddy240=r(tomc)
! g2 y8 _$ h8 _8 u) S                restore/ x9 I  q; h1 @9 C) ~
                 }
( m0 G' W& k. @+ \3 L, |6 ~) `8 ~                 . t7 h- y$ Z# l) B# l3 @
        else {
0 U2 Z7 N% ^6 h                restore + P" k+ V4 D, D1 s/ r
                 di "cannot find pminphddy240"
0 j8 E% O+ w& a/ a$ i                 - G$ \" |7 G6 K5 h/ b# {
                9 P( E- O" v2 o9 ~  f
                 sum dx240! [9 X/ ?$ \) L5 g! G. q
                 local tempminphddy240=r(mean) 2 E  P# H0 I/ J! Z, l% i6 C
               
! O1 m: P6 G+ _5 T7 G$ Z                 
4 |) z3 `9 n6 B% @, V! S0 |; o9 M2 N                 }7 ~- j- \( x! @' u, ?( C
                 & [3 M% v& v! P6 ?2 l& R
   
# y* f- u1 m9 N+ H! i   
1 `! s5 Y2 T  @. m" E   
1 F+ |  f: A2 w! G; Q   
- D* k3 O( y/ R- S   . W- h# S; h! [9 ?! E7 n
        gen pminphddy240=`tempminphddy240' in 1
; X; p3 S7 J/ ^: d7 t& u5 p        ( O$ B( T* I) F5 r/ ^
        3 l7 Y& ?* U* r: @9 b3 P/ f
        *-------------ddy240pminp右侧低峰值 -----------------$ {4 W( v) J* m5 U! q
    preserve
; }6 o! n' n8 V0 a8 Y 2 Q8 [) `, k8 r% _2 \, K( B/ y
   keep if dx240>`tempminp'# U) M5 u1 c8 K( X5 Z. h& }
   
9 C' f% Q- x- ^4 ?   keep if dx240<`tempmaxp'" C# f' X- z% X1 \- s' A
   
+ K9 Y0 E" [3 b% E$ V9 P   keep if ddy240<0$ |: _3 P! ?' a4 R. Z# f9 l6 i5 w9 x
   8 E2 x( B7 ?4 g8 x. m% Y! t) S
   gen temddy240=-ddy2407 p- H- P6 J* x3 j5 v
   
; F7 S3 M* d! r0 x- ^7 C* V    count
$ Q1 e0 I6 E6 `) A9 U/ u, Z               
" K2 }+ d4 }5 |; w" L8 s                if r(N)>2 {
8 e1 B4 _8 w9 ^/ _7 L                 
2 `/ Y& O& G9 ~% q) s& v' T7 X                 pkexamine dx240 temddy240* V+ F. n7 u9 B  h, w, n9 k
   
$ X7 q; R8 u. Y- z. Y" v  local tempminplddy240=r(tomc)
0 ~) Y0 p/ {! g0 w0 P2 E& r2 N                restore: Y. o/ V* D) a' J" }; y! f% b
                 }
( w9 t( U" n' ~                 
% F/ k  J8 k5 G' g% R: ?8 z) @* C/ L        else {
) Z! _/ z1 W8 v               
- @) W5 x. z, e4 V                 di "cannot find pminplddy240"
( @# H* n; E) V9 Q" ~- a/ Q                restore
, f$ V% S2 m8 i3 \, i                 9 c: r1 @% p$ T5 i# D) s
                  sum dx240
7 R/ ]& c) T3 |6 r. \% e5 W1 q" z% J                 local tempminplddy240=r(mean)
0 y- o, @% y1 g' `$ z                 / A2 W' i% p; n. f
                 
- C- d# h8 _$ B4 ~; |8 y# L0 n                 }
9 a  t  T- y9 N4 G( o& H# E% N) Z. E   3 @6 x% u5 B- l, D1 Q0 ~" L9 ~! T' K3 y
    ) D) V# a) g& i! |0 Q) Z- \8 X
   , s! Y( Z! S+ G- I8 m
   
# j4 ~5 Z! W; |) e( X   " x& H- F! i) D! v
        gen pminplddy240=`tempminplddy240' in 1
/ s* l1 M4 }* e# f$ i       
5 S! K1 [9 [0 x6 x        *-------------ddy240pmaxp左侧高峰值 -------------------% a9 h1 b; |5 n# ?$ i# D6 J  A6 J
        . n4 i2 K, q2 x8 B  z
         preserve * L( I+ M% Z7 R2 b
   
+ `7 _5 ]4 H  W+ k' ^* E   keep if dx240>`tempminp'
  r: a* A. {( ]0 h6 g3 g0 ^. n   
' W# i* x& E! X* x3 N7 a. T" D   keep if dx240<`tempmaxp'' L' u- ?' L$ ?9 q+ j
   / N* u9 _5 \4 G/ ?
   keep if ddy240>0" o" D. Y! z0 H: ?! {
   count0 ?" o- n& y) ?" U+ `
                1 F8 y! n6 |# e& o
                if r(N)>2 {
1 }! w9 l( D% j2 z% p  g& m8 z3 g                 & R' m2 a- k. _& }8 \) c
                 pkexamine dx240 ddy240
6 }/ x3 ^3 S/ t1 f! _   
# M* R( p  n, G9 j; R$ U0 n- e8 b1 x   local tempmaxphddy240=r(tomc)
- k) d. d! Z7 @: X& V   8 M9 z  d, l/ M! u( O! ?( T8 ~0 l% p
   restore) @' Y8 ?6 }3 H% C
                 }& f3 g& _4 r* b& S( |
                 
( D/ ?9 O4 u+ q6 [) D7 F  h5 ]1 E5 p        else {: N$ u& [! ^" M
               
0 G6 m' u. c" R3 V                 di "cannot find pmaxphddy240"+ A& U' }3 W2 O7 }9 c* k" j
                 restore# V% t3 q* h2 g. H
               
. g$ W/ s1 W) o- E: z; C( d: W                 sum dx240
7 i! C8 X1 H& F- P* t* ?                 local tempmaxphddy240=r(mean) ' d; C1 @2 K4 Q
                 ; U0 ~8 J# m& G. Y2 Q5 r/ m
                 
0 N7 ~/ P) _) i) I" x$ J                 }
3 L% }+ t3 T: w1 c! E  B3 }; ^   ! N; |% Z5 R2 U8 T) D9 C: M
   " O- X, d7 d) Z6 w
    8 g7 J4 S* H& Y3 t
   
/ s0 n8 S0 l, H7 b7 e: C   
. ^; x1 N9 P, [% X! H: B& R   & I5 p' K3 q" y+ g# N6 a$ a
        gen pmaxphddy240=`tempmaxphddy240' in 1
1 {. j5 Z# E3 I       
& P* ^3 }1 x) }, w3 c9 e, n       
+ [2 R# m2 l- @7 |        *-------------ddy240pmaxp右侧低峰值 -------------------
. k4 n) h4 b' a  B       
9 c9 m' T; A, R( }) o5 G7 A6 _         preserve
0 \; Z2 d: @' k- {* `  : `8 K* B6 w4 |  [- j8 D
   keep if dx240>`tempmaxp'
- O# v% Y$ Y& N4 c   5 |6 {9 y) j7 J, M. M+ f9 K3 y
   gen temddy240=-ddy240
) G( n% h& t( b1 b+ G( U& l   ; q" m9 f0 V* f7 q6 f
   keep if temddy240>04 k8 `4 q- p( s9 l3 Z
   " _; s" g6 n. \% Z$ G
   count
* x& s# `7 Z' T( K( x# a                5 g  v0 I( ~1 g+ @% Q* e& w5 I
                if r(N)>2 {6 V+ i1 @  k" P1 S
                 , C8 n, d2 Y; z: n5 H7 t* s4 f, i
                pkexamine dx240 temddy240$ [: Y( H7 n$ }, h8 ~6 b: d8 ]
   # `9 r3 g7 j5 R5 G
   local tempmaxplddy240=r(tomc)
0 S0 _( a# f3 o4 c/ L  q$ A2 B" C$ ?   restore; }% D. n0 a5 F$ B4 n5 h
                 }( H& B# o# N5 W3 M  A6 |1 m/ R0 M
                 
7 R1 h2 x3 E" o  `. @8 A        else {' H5 F$ c1 C6 _/ f2 n/ O- c
                restore
) o: O0 l0 ^( p1 g; v4 Q0 t4 d                 di "cannot find pmaxlhddy240"
1 ^) B  `9 N3 \) t1 G: N                 + _0 S# q0 \9 Q, v$ @$ P
                : a5 i: i  t0 J
                           sum dx240
* z7 k7 t& Q! i5 q1 R                 local tempmaxplddy240=r(mean) in 1# l5 y. [% {. C% {2 T* W, l
               
/ `5 O  F  Y. d; R  G                 3 D5 q0 W" K3 W* ], x
                 }
# y7 n4 M# ^1 S, l) A   
, B$ @. v1 z( ?   
. l. u' K0 x# J' s+ K    6 m: c: Q6 @7 g, \
   
$ K( c* w' C0 @% R; w% ]   
* [# M( f2 d7 D) Q' R   
2 W* \4 H# s" c% [        gen pmaxplddy240=`tempmaxphddy240' in 15 u% g- T( J. I: ^1 q4 d* K
        6 h! Z- }9 y7 f
        *-------------------------------------
7 ~2 w' h0 O' i. L% H3 r: ^   & y6 F3 g3 B9 k5 [
   gen price5d=v5 in 1/20
: m' g  l+ {# N      
  p8 [7 C0 W2 G% t) C4 F) q% Q( I   gen price5yy=_n in 1/20
- F1 J: ], t/ t4 n' s4 d6 L; c   : U" M" G; X7 n# b* c; Z
   gen price5y=price5yy*(dy240max-dy240min)/20
' g: Z& T5 C# r; W5 z/ M5 J2 X' {   ! M2 o! Y; z/ v8 i- \' `
   *price5y &price5d
0 Y1 W; m( A5 E" |5 A* _5 S   
8 _! h! {6 e3 Q" q- t7 I   gen priceny=price5y in 1
8 B" W1 \" ~9 c9 T   
8 h3 T3 ?: y9 R* q0 ]   gen pricen=v5 in 1
2 A7 Y- A: H+ z' ]  G4 y
4 F  g# Y! |9 v" ~4 h+ I5 s     : F& |! M: e* z  m9 c6 r
   *priceny &pricen! L: b% ]" N1 f
   " _" l7 U% Q, Z1 ]6 W2 s" p. I
   * n' c: X* P; V1 _# h# O8 }
   *-------------------------graph------------------
" v' n4 m' i) J; e) O9 h& |  $ x) T) x) _1 I& w+ |* Z4 P
  tw(line dy240 ddy240g dx240)(spike yxis amean,lc(blue))(spike yxis mean240, lc(red))(spike yxis maxp, lp(-) lc(black))(spike yxis minp, lc(black))(scatter yxis2 amean, lc(blue) msymbol(+) mlabel(amean)) (scatter yxis2 mean240,lc(red) msymbol(+) mlabel(mean240) lc(red))(scatter yxis maxp,msymbol(+) mlabel(maxp) lc(black))(scatter yxis minp, msymbol(+) mlabel(minp) lc(black))(scatter yxis4 pminphddy240, msymbol(O) c(l[-]) mlabel(pminphddy240))(scatter yxis3 pminplddy240, msymbol(O) c(l[-]) mlabel(pminplddy240))(scatter yxis4 pmaxphddy240, msymbol(O) c(l[-]) mlabel(pmaxphddy240))(scatter yxis3 pmaxplddy240, msymbol(O) c(l[-]) mlabel(pmaxplddy240))(scatter price5y price5d, msymbol(O) mfc(black) mlc(black) c(l[-])) (scatter priceny pricen, msymbol(O) mfc(red) mlc(red)), title("`f'") xtitle("`1'") ytitle("density") legend(off)4 G/ d7 r: n9 p9 d$ v
, f/ M0 P( S1 c7 A$ A+ j6 E
* ---------可选项目----------------------1 I8 n( n7 D1 E0 ]! U7 n# ^/ r9 \
' w0 \( v. R$ p5 b
}) r3 |3 N' x( ~' n# f
end) E1 _8 [& r8 F5 u6 ?

作者: 旅途愉快    时间: 2012-3-28 23:23
awer 发表于 2012-3-28 18:06
% v1 h  t& G, q5 I$ o改了一下,这次运算应该没啥问题了

) W, Z) g, M; y' B5 ~这段代码是重新复制粘贴到hello.do里面的?
作者: awer    时间: 2012-3-29 11:40
旅途愉快 发表于 2012-3-28 23:23 ! }2 j) |+ y+ j
这段代码是重新复制粘贴到hello.do里面的?

1 Y1 A5 r; I; F/ c) [( G对的,就是hello里面的那个
作者: David09    时间: 2012-7-2 21:35
awer 发表于 2012-3-29 11:40
2 z, t7 J4 [& @/ K. ]  d对的,就是hello里面的那个
# @* s1 S* z$ X% ~9 l2 V
. hello 002680
" \+ K1 o  g, B. E2 GObs. nos. out of range. Q8 y# q! ~5 I- K' a
r(198);( l) b3 w  t0 b( h# `

& B( Q. W1 C( x7 Y) G8 _; {
! U4 D- D! u; Z) ?我运行后,出现这个,不晓得是什么错误了,请大拿们帮助
作者: qqysc    时间: 2012-7-3 12:12
David09 发表于 2012-7-2 21:35
3 o" ~4 [8 `8 g. hello 002680% c4 ^. i  E( a1 a6 v
Obs. nos. out of range" c* F" N3 p. @' Q
r(198);

. x, m2 F. N; P9 Y6 ?$ h估计是导出文本格式问题。
作者: qqysc    时间: 2012-7-3 12:14
awer 发表于 2012-3-29 11:40 & c0 x- e/ G8 A! F: B
对的,就是hello里面的那个

/ z0 `( ^( ~1 G7 N  {4 [复制粘贴有很多乱码,请楼主把上面的代码做成附件以供下载,谢谢!
作者: David09    时间: 2012-7-3 17:13
本帖最后由 David09 于 2012-7-3 17:28 编辑
4 x" A% S6 x2 B% h9 g
qqysc 发表于 2012-7-3 12:14 ( \$ ?( H( A: R# |4 W! I7 e% f
复制粘贴有很多乱码,请楼主把上面的代码做成附件以供下载,谢谢!
+ T% ]8 _% D' f& ]  F1 T2 J

; r) `4 B, h* M4 B我清除过了乱码的啊....
作者: qqysc    时间: 2012-7-3 17:56
David09 发表于 2012-7-3 17:13
6 Q1 p2 S6 s  i我清除过了乱码的啊....

, I7 W( O+ ?% |2 J说得不是一回事。你说的问题可以试试在 002680的文本中,把tab键补齐,导出时不要带表头
作者: David09    时间: 2012-7-3 19:45
qqysc 发表于 2012-7-3 17:56 , w% Q. W0 c& j; M( q
说得不是一回事。你说的问题可以试试在 002680的文本中,把tab键补齐,导出时不要带表头 ...
' ]5 o' p, u/ M& b( |) @+ ^( {
很奇怪啊,我看stata中间的数据表,都整整齐齐的导入了成交价成交量。但是一运行就蹦出来那个错误
作者: David09    时间: 2012-7-4 14:44
搞定了,原来是我选了一个次新股的数据,样本数目太少了,引起程序的错误。
' H2 l7 X# I" }9 U7 T感谢楼主给的好东东。
作者: 碧水芳洲    时间: 2012-7-13 13:40
怎么没人问曲线是什么 意思呢? density指标也不是很明白呢,谁来解释一下?
作者: benhuashu    时间: 2012-7-20 15:16
请问,这一个语句:
8 w! @3 B) B- H) h: r3 ~gen zf=D1.v5
: E( N" e* z- ~1 a% R+ l5 r% C* l( o是什意思?主要是=之后的D1.v5,这个"." 是什么意思?谢谢。
作者: 海阔    时间: 2012-11-5 18:37
非常感谢;
作者: 墨轩书童    时间: 2012-11-7 11:46
本帖最后由 墨轩书童 于 2012-11-7 14:37 编辑
' _/ f, i' `2 D/ G% v# @- @2 q
% e9 R8 d" V6 b. y感谢楼主!!
作者: 海阔    时间: 2013-1-20 17:03
本帖最后由 海阔 于 2013-1-20 17:08 编辑
" b8 O  a& q& V# r" D; N  e. B2 v+ Q- |
按照版主的步骤操作到了最后出现
1 n: x' o/ s. @! i+ F" H0 a4 [5 x
  f0 J" d4 M' @$ G3 ?" f. hello 600031. G: B* f7 l" M  i/ |4 j/ U' X9 p
avolDo not found$ o- _, m3 L/ Q: a' v5 P2 m
---------------------------------------换成其他代买,也是一样;总是出现这个问题,怎么办呢?奇怪
作者: maodeng    时间: 2013-1-25 13:15
大师,那两条曲线代表什么啊# r/ x$ D# Y# p# i+ G1 }) w

作者: maodeng    时间: 2013-1-25 13:15
如果我想看最近 一个月,三个月 六个月 的成本,怎么修改程序啊,谢谢大师了
作者: maodeng    时间: 2013-1-25 13:18
我用同样的方法导出数据,发现有的能生成,有的就不行,不知道问题在哪儿,比如300236就生成不了,我的邮箱是19860225gaoyuan@163.com,麻烦大师了
作者: maodeng    时间: 2013-1-28 13:13
. hello 300236
9 V! z: V# q( k! P/ ~: ]. pstatement out of context) w. [' k! l& k, ~# [6 A7 E
r(119);
2 |2 x  v$ q% N8 t! j! u6 J2 X! U6 j2 |; D; I, T
大师 就是这个
作者: sergio    时间: 2013-1-28 21:11
这贴实在!
作者: awer    时间: 2013-2-5 14:40
maodeng 发表于 2013-1-28 13:13
" Z1 ]2 P: S0 I" V. Y. u. hello 3002362 w8 b1 b( y% o+ K8 b, Q
statement out of context
) \+ |: c, m+ R5 W' H2 l- Ar(119);
% ], s/ L. Q+ t' X0 [8 X3 p
抱歉,最近太忙了, u3 }- Y1 @  b  e

$ O5 f: P. j  Q: i1 B  ?300236 我用下面的程序试过,没问题
! X7 X. Q. Y6 n. @* E
1 P+ U" b$ V! g4 o你把 D:\stock\test\source 改成你导出的数据存放的目录,再试一试
4 Z4 P* j; S. i5 o! B, K4 F) g- R: V) q" i8 I
capture program drop hello
& ?/ I- P2 ~. Y; z" J) W8 x5 a, E, B' o% U4 ~) F( b
program hello' S( [6 K" E' R7 P7 e

& m0 x% Z3 k$ c, @1 ] quietly {
$ U! B2 J8 `0 {- Y5 C1 }* L: v
4 u, G/ j+ A7 u% M6 Fclear4 r7 g* ^: I3 X3 g" O+ Q: t
* Z% l( h% a; O8 @7 x. j
cd D:\stock\test\source7 a4 l/ X) B- o/ S. `; z( x( F1 l
5 @) _$ V% u- }7 d- c
insheet using `1'.txt
/ l7 H6 O* V7 I8 B9 T  Q* z8 M6 U
: }1 V/ B8 K1 g2 ]   keep if v5>0! }* _# [# c1 j% ~" C
   
" _* c% q( }/ a2 Y' F3 E   gen vt=_n" Z, B5 W& S% p3 s+ U, Q
   
1 u* U( a% s! \* B6 a   tsset vt
. h2 N" h  h8 ^4 d8 i0 Q  ~2 G& _7 M/ K; R( T5 }) k
   gen zf=D1.v5
; T5 M$ h, z+ c% {# L; f* m  A- L4 x3 U+ Q, T2 K. }" n5 _- T1 h
   gsort -v1
) W; I2 W* X# Y2 [$ n- ~4 p& K+ b* S2 i8 T# ^  |1 y" L
   gen avol=v7/v5
; ]# B+ R; o! j   
$ \0 X( k2 T! M3 U   keep if avol>01 c$ {0 B2 h$ }7 t% g+ y
   ' B# @3 Q* v) R* X
   drop vt; }1 T! w, l6 @& n! b/ f. C9 T
  
* m% w1 ~2 O! u9 }   gen vt=_n
- v$ y& u( h8 R  z   4 D/ @4 z9 c5 T7 p# w
   tsset vt
, j0 ^; }# Q% O, E% ]) W+ K   
/ {: C8 M  f) f3 q    sum v5 [aw =avol]6 i' U% x, W7 ]6 _3 P
7 |# Y9 X% K) [0 k3 g1 }
   gen amean=r(mean) in 1
* u! F# t$ ^0 f# p   
& u3 V0 J" k- D9 n   * 总加权平均值 amean
2 |5 _+ V0 n; f* A   # K! W) R: z  L. c. P
   * s2 n# |8 Y% m2 m
   keep in 1/240
$ @* q; r6 D# {2 U
- _0 }) z- a9 o1 j! K1 g2 T   sum v5 [aw =avol]
# p1 L( l$ ~& g0 X1 N% `7 _* w) j9 Z9 Z, P' o$ R& E
   gen mean240=r(mean) in 1
+ G& h/ X3 Q  `# D0 Q. X+ B   $ {5 z, l4 w" Z
   *240加权平均值 mean240
0 _5 m) i, F" O& g) A& S! x   
6 p8 {  G) O+ v   set obs 500 $ ]+ U+ s0 y4 ?( ^. y7 F, I( L
   
3 j$ n8 U* Z, R. N. X) d+ S   kdensity v5 [aw =avol],gaussian n(500) generate(dx240 dy240) nograph
' ?+ A4 \$ \8 V4 [: W2 C   1 n1 O. s4 ~0 B
   *240 kdensity(dx240 dy240); |3 ~8 h% V0 J" d7 t; R/ Y7 M- e% y" o
   1 [+ e. W( L1 E7 J$ O" W
   sum dy2400 \- ?) D+ O5 C
   - X8 ]  y* V4 i( d7 |
   gen yxis=r(max) in 1
+ G; m- e9 [- r6 }* W( c2 q   9 d* Q- o: Q6 Q6 t; D! P4 M  I
   gen yxis2=yxis/2- ?  v$ r4 O) [3 l: \
   
" I2 v$ d1 D; ]/ E$ W   *yxis
" {) Y7 d% K2 @9 p. [   0 i: u! A( {/ y
   gen dy240max=r(max)0 ?" H, Y: }+ {1 k0 Z2 T. I
   ( D; q9 U, M/ ]! i9 h
   gen dy240minp=r(min)
3 D! C; s+ X7 F' ~4 e( m7 k
. U  a) u4 K. Z8 T9 i  W    gen vtt=_n
0 C. ~4 Y) M8 {- f5 }& k! W5 I% @) t0 a. E( E" x: t. r- N6 l2 t
    tsset vtt  E. k0 ]. p6 c# b; {6 ~" Z

* ^/ I" k2 C/ c  r' L5 T, v3 E' }( k   gen ddy240=D1.dy240/D1.dx2407 Y, F6 ~. ]1 [1 D9 j. {
   
" W: f7 T! ~5 y8 @) e   sum ddy240' k7 f8 c0 ]$ ~. Z/ t9 {& |: \6 s0 M
   . C0 s6 s3 I" B1 M( {6 G7 [! H# q  E4 h
   gen ddy240max=r(max)
1 j7 T+ a: N8 }+ ^# f$ V! i- u   : l. f  @% i, N% d
   gen ddy240min=r(min). h1 v' y) d* ?
     
7 _2 u! b) }, i3 q6 a7 f! g( M   gen ddy240g=ddy240*(dy240max-dy240min)/(ddy240max-ddy240min)
" W* W, ]9 H9 }   " Q! U% g5 n6 t
   sum ddy240g% Y& \& I* T4 a/ v1 b9 u$ Y
   
! j3 }; _$ h; G5 t" i; F   gen yxis3=r(min) in 1
5 B. t/ a$ I* i$ M% r  u% o' h+ p   9 O. g! x. t2 i+ A$ z. j6 G. k
   gen yxis4=0 in 1
8 b( W! P, A, f- F& p  
- s+ r) L. ?: O. Q  *ddy240g 0 o7 J( j% p  U( X
   
! b0 Y8 Z: Q% c) n8 c( Q   
; C. }9 j  _; V) P' C- t/ ]  preserve
3 q3 {: k) I* E/ V  5 z( r# z( D) Q& J1 @; V* p) Y
  sum v5 [aw =avol]
1 J- H1 F" M: n+ Z) d, e4 j" V  
1 `( V; F' L) `# M( t& f  keep if dx240<r(mean)! L( m% T% b; X4 {8 G8 k; n
  
0 z" h# t( w* U/ z3 B$ A4 x* Q' s  sum ddy240
( f$ R$ W, v# W+ i8 Y" m; T  
& k4 ^; L+ y: g$ y+ O5 B  if r(min)<0 {
2 q# v+ C  O3 O; g        $ X0 a' c/ V: x* K: V& A
                keep if ddy240<=0( _9 p( ^# N3 Y0 k2 a" Z' _
               
& ?7 `4 t% ^1 Z4 P( F% ^                count; O, k4 @: |- t, @, n
                0 G! x7 o% ~  K% E4 p
                if r(N)>2 {" r# E$ W7 C7 D
                 ( f. J$ h* u9 p/ q
                 pkexamine dx240 dy240. s. W1 Z: {7 Y+ c9 g* A
               
3 c, `/ [# o6 s+ M' ]  ?2 s6 c+ u2 j                local tempminp=r(tomc)7 [5 I5 F6 W4 I% |8 r
                restore " c2 q$ N. H8 Y3 H# o" f
                 }
- F& T3 Z% `( Y+ ~7 C! w. B                 
" ^- J# i3 o+ [4 x) [5 b        else {  Q% j. i: c# I; S3 k$ ?
                " N! L  h% T" U$ A( q. o! E+ z: s
                 di "cannot find minp"5 x7 l8 ?2 i7 ?0 e# z# Q% O4 D
                 
3 M" G: n# i. ]% ?; h6 E. J                restore 3 Z) C- r$ x2 X5 ^$ W
                 sum dx240
& j1 B) {! Z' W, s                 local tempminp=r(mean)% ]) S( `7 R9 F
                 
7 z2 s7 G" A" U- a                 }2 ]! {( ?+ k0 ?6 u; z
                }
9 u% X2 g$ b/ N6 n! I: t   else {0 j* E3 L  }* Q2 h( W( n
                 ; N% |  O! F, Z* ~% O' g! s2 ~1 i
                 keep if ddy240<=r(min)+ R; B* _1 J6 a; o
                 9 b0 a$ U8 N* V; }# H
                 sum dx240% L) T% m* x, [5 t
                 2 l" f  p, G- k
                 local tempminp=r(min)
- c7 }+ Q4 z$ t6 ^" e                 restore ) B) \- E) v; B! V9 O' `
                 }/ P4 C% r) I; |4 E( N: O

. }# Z$ f6 M) z+ O& Y' v- j! h
) k; C" n+ O' G7 [( J5 o' G* f$ A1 d
   gen minp=`tempminp' in 1) e8 _  M! ]( {& n3 o
   *240 minp! i* C$ v+ k9 y& U

1 |) l9 F- c1 Y: n7 t
' B: a  K' S9 ?# K6 U% o" q   
- k( k* ?7 A+ y5 M   preserve . [9 ?/ k+ t/ }' A/ |, p2 a% U
   
! A% K7 z/ o3 \; I: _   sum v5 [aw =avol]
" ?# L6 s8 L: S/ ^, \   . e# C/ Z9 w. i* u
   keep if dx240>r(mean)
0 O- n$ N; o, D4 m   
2 L) T8 o$ J* L* I9 u# ]   sum ddy240
1 U% {: [. O) [  }; t0 M* Z   ( ?, S- Z& K+ K# `7 p
   if r(max)>0 {% C- j7 Y; U  g- e( n1 |
               
, i! E6 A9 i" t! d: V4 R' Q3 G                keep if ddy240>=0/ X5 ^' G# I$ v. v7 o1 L9 t3 r
                ( H4 k2 U) X+ W* c5 ^
                count
9 C6 U- C& ?; F( b                6 G& b% F+ @* t( w3 i; C
                if r(N)>2 {7 Y/ y# Q2 @7 P# @
                 " @8 }" L; J  G3 ]
                 pkexamine dx240 dy240
0 g: B' o  m  ~) `7 H; o4 a" D                . L8 W# m% _) y8 ^
                local tempmaxp=r(tomc)
4 w, m: \+ {+ F6 @. f                restore + h# Q# }. k2 U2 ]- B3 y/ n
                 }7 g3 @- l% \; Q) r% n
                 # F" h* ]3 |3 S4 U
                   @1 ?# _/ j$ b0 `" |6 |. K
        else {
6 |2 v3 W$ s+ C( X5 s5 n( X5 ]5 R                restore
& R* ^/ D: u3 B% g0 F                 di "cannot find maxp"
6 b3 ~5 A0 x" d, \% O  S               
+ Q' j3 x) X( F' w- H                6 D3 n. ~8 H# c' N" r* A- |
                 sum dx240
( S( U( }5 a& P                 local tempmaxp=r(mean). M5 H$ g, u/ E5 U6 O% }
                 1 s* t% L1 h  A0 e3 G: D
                 }  U: F5 X% _4 t9 P; V8 p
                 
; P! `" Q2 C# [! _9 l  s7 i* ]                 }$ C" V  S' E8 `2 ^
                 4 t- n/ v0 [5 z7 u+ o6 o( W
    else {
: ~/ g7 _7 W5 ~4 b7 l: |  ?        0 g3 u  s: d( m8 l+ h1 J
           keep if ddy240>=r(max)- A: y- L' x( s7 x: x1 |
           0 d0 I0 v8 E5 i" W
           sum dx240
' Z4 ^# Q3 s! P; U5 U: D           3 ]& z4 C% {0 \5 I
           local tempmaxp=r(max) - p* k/ O; u2 Y% z( S' K$ P1 K
           restore
5 G+ b0 M7 V5 J, c1 X, d+ k+ b: S3 ~           }# O  ?8 P# A5 c  V( ]
       
" ?3 v* |9 F% K7 ~
. S" j: ^, Q: T4 f( [1 u  u9 [  
. }7 c4 O7 N. ^9 I) R* p  I7 O+ B$ y# z
   gen maxp=`tempmaxp' in 1$ X9 _% j+ W2 }
   - g7 I2 j/ d5 u1 [+ k0 q. r# R5 h' n& {
   *240maxp
6 G; X; M/ _( r% W, I  g& L   / y: d, O: h* @1 P
   
/ t9 B# v, {0 m+ [/ G   *-------------ddy240pminp左侧高峰值-----, U8 x4 H& ^4 M
   ( s" K  G3 p" P$ P+ k
    preserve 6 j6 F- T4 r- P0 w3 C
   ; b! r  }3 p5 B! r8 a6 W+ n
   keep if dx240<`tempminp'- U8 \( r. z2 O; H: M8 V
   # Y$ c, P) X. y) [
   keep if ddy240>0
% {2 \# {8 f( `9 v9 A( J3 \   
. P6 k9 W+ t" q% `5 U# w. z4 J6 E% F2 u# R   count5 p. f# ]- I2 i1 y& R, W
                & D/ K' q# x- W5 [& M
                if r(N)>2 {
5 H- b- l5 M& k$ X% ^* P4 A                 2 o% p8 A6 g' v
                pkexamine dx240 ddy240- f9 x* R1 @2 B& o! P
               
8 m4 i/ d, }8 _2 H. Q                local tempminphddy240=r(tomc) " z# B0 P! {  L2 t: g
                restore6 w2 @7 a" m% q% j& I8 [& }' B
                 }
, L. u* X3 q# n/ y) ]: b' R# {, ]                 
% P- b5 N0 c/ F% C7 Z; T% l/ z+ a        else {
" s: I1 o0 B. g/ Z* A4 X                restore
1 T$ Y2 k# j, p. ^& A. p! J* x                 di "cannot find pminphddy240"& g: E3 S) m$ U3 c6 T3 v
                 
9 Y& R# ?& ?2 [, O1 ^  Y1 ]4 n                " {9 X7 b7 M6 t" _
                 sum dx2409 |; s7 c: L. l4 r9 ~4 X: j$ n
                 local tempminphddy240=r(mean)
9 k- h0 r- j7 }) |1 H" v7 H                5 K5 Y) ?& V6 B& J
                 
  E5 r* u3 i1 G& o. O+ v                 }
$ v1 `$ K4 t/ m' E                   K. L. c5 s# A
   $ \! ^5 I3 }8 v% j! U8 H" G4 l, i
    . P8 f' k0 |6 P# o
   
4 R& _/ E/ X: T( n8 `   
( h" T# v" O  T% m$ b6 B   
, l6 Y9 _# r( D" [: s$ f        gen pminphddy240=`tempminphddy240' in 1
- S& K" `" r* k       
8 o  O1 `6 N( z% s2 J7 V& D       
- t& m0 v! |- t! y1 Q        *-------------ddy240pminp右侧低峰值 -----------------
/ Q; q0 j5 @9 N" Y6 m- p1 r    preserve
# |* z( f* f# V' X: D 3 O9 [% L, i! j5 W' {. b
   keep if dx240>`tempminp'
9 Y: Y0 k, s! \# q: p9 L   
1 |& c9 F  t9 o9 P" D; C1 ?   keep if dx240<`tempmaxp'# T0 h$ F# D! W
   # |5 g. o! f, W
   keep if ddy240<0
/ f# o1 Z' b# W- @& c3 L- i! u9 |   
5 w" k- u) p$ e$ W" H' k/ Q2 L   gen temddy240=-ddy240* R: G! t" r( _( Z# q( e0 K
   
5 o7 n. G% X! @, k6 v6 l' M  J    count( Y' X3 b+ j" z1 H
                4 a' K' c- C! r' @
                if r(N)>2 {9 d2 d9 M9 x1 C: @# Y
                 ' ^+ u0 U0 b1 Z; Q6 J1 j
                 pkexamine dx240 temddy240
% d9 J/ \4 O* p7 w0 E( s; M   6 d) ^. q( o1 r" G
  local tempminplddy240=r(tomc)5 T9 L' v8 d- g2 O2 e1 `4 V
                restore
# z& x- U3 q0 g9 |$ O& n, z  b2 A                 }
9 X" H9 X- J: _                 
7 t" V0 o$ C; C        else {4 M9 ]4 h4 B0 \5 `: K
                0 c8 R  _/ D2 r: |* R
                 di "cannot find pminplddy240"( l. r/ }5 Y: L# l3 f0 o1 z
                restore
# F! H6 i$ F" q                 2 E  Q. r* c' g' C$ b0 ?
                  sum dx240
# F' z! m* y5 e; l1 k7 r+ s                 local tempminplddy240=r(mean)
: d8 _7 c( y4 F. U4 U7 d5 ?  i" w                 
- P  i  I8 ~( f! u+ ~                 " t1 Y+ Z7 q6 m' v
                 }
  N8 Q# [: D( R6 r; \2 a   
; S7 z0 z3 m' M$ D3 g7 b, D/ _) c    ; ?2 a: W7 l- R
   
5 P( Y; h+ {  F3 e, |; [5 |! [# C6 c   * N: d  m0 n7 P3 _8 e
   
- N+ T4 y) A0 @( e1 k  B/ q        gen pminplddy240=`tempminplddy240' in 1
/ j2 z+ D: W9 |3 ^$ ], D) I" ]$ a       
$ a+ q: J# g1 G9 B- g4 N" W        *-------------ddy240pmaxp左侧高峰值 -------------------, a1 f6 F& ]1 r& L* a5 h; k
       
" V6 A! c  }" k4 I         preserve
" P: E: ~4 _2 a5 ?9 A! k$ d$ n7 Y1 ?   4 J2 k) E* U) j. J9 y
   keep if dx240>`tempminp'
0 [7 i3 @# g* z+ P# g2 p% z   , E/ B# ^2 P6 O' P$ _2 H
   keep if dx240<`tempmaxp'
7 D$ `: c, K; v! X# ]$ \& H   ' G4 L; P. R5 E* e' n: [) L
   keep if ddy240>0) P- a( O5 b9 l0 |  ~7 j% h
   count; B! M" }, [) [1 A* \/ X) D
                1 u0 w/ K3 E8 H8 G- k; t
                if r(N)>2 {
! y) N, f4 J& c! W$ J, v/ I8 I& f- _                 ) V8 r! y  x+ c2 c2 B
                 pkexamine dx240 ddy240
$ Q  \+ d  B7 w5 |- z* c- J   
; ]: B4 j2 {/ i2 Y' e$ w   local tempmaxphddy240=r(tomc) 0 L2 H9 C9 a, Z& m- u& P
   % R8 U8 ~! W9 l' ], d, f2 l! l) i
   restore
) a5 {# L  `1 m" t0 \+ |                 }/ m4 @+ Z% t* n! ]% J: f( [
                 
$ S: j; e! \7 }% R        else {, F4 W& X3 W  P- h: F
               
" Q! r6 N# n0 j3 }9 g                 di "cannot find pmaxphddy240"
' k8 z+ Z7 b: f1 v1 y                 restore" f) g. u0 L: N6 U
                8 A5 a& J! [) @
                 sum dx240
5 U+ H  S+ h1 Y+ y" Q! i3 G                 local tempmaxphddy240=r(mean)
# e: D% t! K, m  O* |# p0 I                 # D' G- L. \" M' X; r! n9 l% y
                 - u. X+ b/ o+ N: P) \* ]" ~2 O7 |/ Z
                 }( g2 z% [4 u' E+ l1 S% W3 Y
   2 B, W- @: x7 D6 G" r
   
+ ?- e- Y. h! ~, e/ N4 v    3 ^+ S3 J  D' A1 M$ R& N! P' @* W
   
- v2 V3 I! o( k- R. X7 m7 t   
, j0 P/ M. v3 {5 j+ t( K: f8 P9 Z   
3 \7 q  x. W2 P6 {        gen pmaxphddy240=`tempmaxphddy240' in 1
1 v6 I: G- d" B" i       
* X3 A$ p  n- x; N, y+ A        % j* r1 z. j* S. s. \! K5 o9 r+ k
        *-------------ddy240pmaxp右侧低峰值 -------------------  K/ H" J2 y) u% ~/ r- y9 t9 N. X
        4 h  k3 j; Q# z2 @( C
         preserve 0 I! Y- b6 I1 h& X
  - p" Y$ G- @# |" t$ I5 b6 V
   keep if dx240>`tempmaxp'& k4 z$ b* c  Q& g3 D
   
$ M5 i0 T' @, [: c   gen temddy240=-ddy2408 T- I; w* t5 j4 n" O# N! f. w
   
9 k7 u+ ?7 u4 P5 i" b& c   keep if temddy240>0
! v: v# I# ^) S( u. M+ i   " Y" A8 H, A9 V1 ^  v2 n
   count
+ H, x' v+ c9 @! }$ |/ {+ z7 L               
" \$ f& H' n" K7 O7 [                if r(N)>2 {( @; p8 A/ N7 a
                 
/ B$ Z7 J8 W# W, ~* A7 d' [) }6 t                pkexamine dx240 temddy240' S' c# K/ I7 l$ F9 Y
   - c* O( W  H3 r4 @% y  J7 O
   local tempmaxplddy240=r(tomc)
# n$ s1 A2 G( P- \& J9 C   restore! L4 `3 O2 W0 b$ P9 k
                 }
6 n# V  o! z) l1 S) f' Y. r                 
! s9 `  Q. K8 P: h+ E        else {8 K+ s2 [! g3 m% M+ b
                restore7 ]# |4 I) {3 A
                 di "cannot find pmaxlhddy240"
2 u& J8 {* H- N) K! `  y8 w) N                 
" N( U1 z. H% ^, Q7 X               
! j# c6 \1 ^5 i5 j# W                           sum dx240
0 b' W& t3 t5 ^! h$ f) _7 P                 local tempmaxplddy240=r(mean) in 1
. \( c4 a! T; y& ?4 Q# ~& Q' m. ~               
. Z: c$ I' o3 G" g                 
* b7 O- x0 B( a/ \9 J                 }
1 G# m+ b* J" Y1 ~( v" k' y- [2 G- f   
# j( }3 a5 O  [  Y  R3 a% E   
4 q& k* _$ B$ Z: n3 C( Z8 ?5 s; |    & q. i4 k' r  y4 b) G- C: D& y$ B1 j
   
" Z/ j8 D: G; n  T; h   2 Q2 \$ F# a8 e) M" C7 n* @* s; x
   
+ _0 a/ l3 w8 G        gen pmaxplddy240=`tempmaxphddy240' in 1
: U: z4 p6 T& Y        $ D; T- I) L" s
        *-------------------------------------
7 {/ q9 \/ Y% g& b- n2 A   . d& A' n; t/ k. P
   gen price5d=v5 in 1/20! ~3 C7 [# p( A2 M; T( ?9 h4 c; p: q
      
# z) G! ?  A1 G3 j' ^" p   gen price5yy=_n in 1/20
4 v6 A" d) x! i, O   
, c0 Y( M! m! o2 @; Q4 v   gen price5y=price5yy*(dy240max-dy240min)/20
% ]* S: a9 [- r1 {' H   
  q5 u* M; \. W  C! s. P3 ~3 f: _   *price5y &price5d
$ J* Y$ T  N) d2 {9 U5 ?% S" \8 c   
+ F: n8 ~" H$ X. X- T' o5 v, E   gen priceny=price5y in 1
$ n( @; x; \+ R) E   
' L8 V1 A/ E, K5 t7 L   gen pricen=v5 in 1
# }5 q0 \5 ^; Z% u  @$ q7 }
" Z- g+ V! V& @9 F     , @0 ]% _' f7 Y& q% D3 V
   *priceny &pricen/ c: g$ W: U" j7 a' n
   4 O* T0 l4 \: l: u
   * O! I$ v# I) ?5 w! _
   *-------------------------graph------------------/ U2 f- D& h/ k" ]4 O" ~" j
  - Y# d3 Y  W/ x% B3 ]" s- q
  tw(line dy240 ddy240g dx240)(spike yxis mean240, lc(red))(spike yxis maxp, lp(-) lc(black))(spike yxis minp, lc(black)) (scatter yxis2 mean240,lc(red) msymbol(+) mlabel(mean240) lc(red))(scatter yxis maxp,msymbol(+) mlabel(maxp) lc(black))(scatter yxis minp, msymbol(+) mlabel(minp) lc(black))(scatter yxis4 pminphddy240, msymbol(O) c(l[-]) mlabel(pminphddy240))(scatter yxis3 pminplddy240, msymbol(O) c(l[-]) mlabel(pminplddy240))(scatter yxis4 pmaxphddy240, msymbol(O) c(l[-]) mlabel(pmaxphddy240))(scatter yxis3 pmaxplddy240, msymbol(O) c(l[-]) mlabel(pmaxplddy240))(scatter price5y price5d, msymbol(O) mfc(black) mlc(black) c(l[-])) (scatter priceny pricen, msymbol(O) mfc(red) mlc(red)), title("`f'") xtitle("`1'") ytitle("density") legend(off)9 H9 Q. F6 s' S
+ p2 ^! E, l4 K% j- U, _- \
* ---------可选项目----------------------* `) [# Z2 x0 s' w7 U
*(spike yxis amean,lc(blue))(scatter yxis2 amean, lc(blue) msymbol(+) mlabel(amean))! C' b/ V  a4 Z1 T
}6 h( v2 |9 r/ _+ G9 a, k
end- a. T; B1 y: b/ V

作者: maodeng    时间: 2013-2-7 00:03
awer 发表于 2013-2-5 14:40 0 L1 |: a7 _4 B. n# q- A
抱歉,最近太忙了
+ M, x, x* j/ X  H/ c( Y( R% t0 _0 \3 Q$ U( ]9 l$ e$ \
300236 我用下面的程序试过,没问题

* S0 Z7 ?( K0 z$ l哇,谢谢,我仔细看看,这些字母数字代码晕了' j2 U7 X, \6 ~: |; V& I+ @

作者: 喜欢喝冰茶    时间: 2013-2-7 04:05
stata是不是商用的,R里应该有类似的东西吧
作者: 喜欢喝冰茶    时间: 2013-2-8 07:16
awer  老虎推荐的一个处理数据的软件,很小,只有10m左右,很好用  发表于 5 小时前

3 s( z7 f" I1 T! C. z# V5 m& A2 ~
这东西是开源的?知道有个统计软件叫stata,不过要收钱。
作者: 汉水云潇    时间: 2013-4-17 17:14
准备试一试
! d9 p" n3 i. @: L先找Stata软件
作者: 汉水云潇    时间: 2013-4-17 22:21
本帖最后由 汉水云潇 于 2013-4-17 22:27 编辑
; o& c8 v3 l) ], f' O' X! T) _! ]7 V* {* f- G( o
晕呀3 \/ C: K2 v6 d7 X$ Q$ c
论坛复制程序代码
. y6 h# N6 Y/ q- D! r" ^乱码夹杂在其中
/ {! P8 K- `1 @" S6 b5 z% L很烦
. d9 K4 ]5 _8 V! ~$ h! B/ ]8 K7 i对了两次5 I8 a# [3 F9 n6 w/ @' W4 Q
以为没问题了  P$ T4 q4 |" ~/ I
$ c" M8 z) j: B" Z5 u- I6 y7 c
结果
# q' n! q" N; V" x% b& m9 s( f0 }执行后% h' y2 J( N- a% {" g$ v
还是出现0 v" r6 e0 S& E9 l  L" U6 i
r 199
: M: w+ X% \" F5 P  _6 {: ~5 ^的错误
) o) j5 Y4 z) J* g, U$ f
作者: 汉水云潇    时间: 2013-4-18 07:50
试验成功,下面是三一重工的图3 Z+ P' t; s, F) u; O& l; f
5 [3 A+ e+ W% A9 ~

作者: peterbev    时间: 2013-4-26 12:46
先用用试一试,不知道准确不
作者: 中秋不圆    时间: 2016-3-12 15:46
噢。。。这个帖子好,比较直观。
作者: bknite    时间: 2016-3-21 23:51
这个帖子值得学习。
作者: jeanny    时间: 2016-3-22 10:41
感谢!!!
作者: Hubert2000    时间: 2016-3-23 10:23
明月回春 发表于 2011-8-13 20:17% U- z' A9 T+ e( {( [; t3 j
程序写的不错.' v- @& o+ e0 W& u7 R
不过有一点要注意.通达信导出的数据,只对价格复权,并没有对成交量复权.所以数据需要手工处理 ...
, T$ R9 F, t8 n( r. P
老哥,也是山寨这篇文章找不到了,不知为何?
作者: axiutime    时间: 2016-8-3 13:28
提示: 该帖被管理员或版主屏蔽




欢迎光临 爱吱声 (http://129.226.69.186/bbs/) Powered by Discuz! X3.2