Thursday, 31 October 2019

python finance 3 rolling average

daily stock price, 100 day rolling average, and trade volume

synchronized zoom on volume and price graphs

df = pd.read_csv('tsla_csv', parse_dates=True, index_col=0)

#100 day rolling average, for the first 100 days, average beginning to current day
df['100ma'] = df['Adj Close'].rolling(window=100, min_periods=0).mean()
#df.dropna(inplace=True)
#print(df.head())

#price graph height 5 x volumn graph height, share x axis (date)
ax1 = plt.subplot2grid((6, 1), (0, 0), rowspan=5, colspan=1)
ax2 = plt.subplot2grid((6, 1), (5, 0), rowspan=1, colspan=1, sharex=ax1)

ax1.plot(df.index, df['Adj Close'])
ax1.plot(df.index, df['100ma'])
ax2.bar(df.index, df['Volume'])

plt.show()  

reference:
https://www.youtube.com/watch?v=QAkOnV1-lIg&list=PLQVvvaa0QuDcOdF96TBtRtuQksErCEBYZ&index=3
https://matplotlib.org/3.1.1/api/_as_gen/matplotlib.pyplot.subplot2grid.html

Wednesday, 30 October 2019

Python Programming for Finance 2

Tesla stock 2011-2019


import datetime as dt
import matplotlib.pyplot as plt
from matplotlib import style
import pandas as pd
import pandas_datareader.data as web

style.use('ggplot')
#save web data in local csv file for better performance
'''
start = dt.datetime(2011, 1, 1)
end = dt.datetime(2019, 10, 30)

df = web.DataReader('TSLA', 'yahoo', start, end)
df.to_csv('tsla_csv')
'''
df = pd.read_csv('tsla_csv', parse_dates=True, index_col=0)
#print(df.head())
df['Adj Close'].plot()
plt.show()

中国央行或先于全球第一个推出数字货币







Tuesday, 29 October 2019

Python Programming for Finance 1

#powerShell
pip install pandas pandas-datareader matplotlib beautifulsoup4 scikit-learn

#pycharm file->settings->project->interpreter->install libraries

import datetime as dt
import matplotlib.pyplot as plt
from matplotlib import style
import pandas as pd
import pandas_datareader.data as web

style.use('ggplot')

start = dt.datetime(2011, 1, 1)
end = dt.datetime(2019, 10, 30)

df = web.DataReader('TSLA', 'yahoo', start, end)
print(df.tail(6))

-------------------------------
#log
                  High         Low        Open       Close    Volume   Adj Close
Date
2019-10-23  256.140015  251.350006  254.500000  254.679993   5261100  254.679993
2019-10-24  304.929993  289.200012  298.369995  299.679993  29720900  299.679993
2019-10-25  330.000000  296.109985  297.720001  328.130005  29982400  328.130005
2019-10-28  340.839996  322.600006  327.540009  327.709991  18860900  327.709991
2019-10-29  324.299988  314.750000  319.989990  316.220001  12673300  316.220001
2019-10-30  318.790009  309.970001  313.000000  315.010010   9637000  315.010010

-------------------------------
#log print(df.head())

                 High        Low   Open      Close   Volume  Adj Close
Date
2011-01-03  27.000000  25.900000  26.84  26.620001  1283000  26.620001
2011-01-04  26.950001  26.020000  26.66  26.670000  1187400  26.670000
2011-01-05  26.900000  26.190001  26.48  26.830000  1446700  26.830000
2011-01-06  28.000000  26.809999  26.83  27.879999  2061200  27.879999
2011-01-07  28.580000  27.900000  28.00  28.240000  2247900  28.240000

reference:
https://www.youtube.com/watch?v=2BrpKpWwT2A&list=PLQVvvaa0QuDcOdF96TBtRtuQksErCEBYZ&index=1

Monday, 28 October 2019

react native zoom view


original

zoom in to see license plate

pan

zoom out and pan

zoom out

furthest

npm install @dudigital/react-native-zoomable-view

import React from 'react';
import { View, Image, Text, StyleSheet } from 'react-native';
import ReactNativeZoomableView from '@dudigital/react-native-zoomable-view/src/ReactNativeZoomableView';

export default class App extends React.Component {

  render() {
    return (
      <View style={{ flex: 1 }}>
        <ReactNativeZoomableView
          maxZoom={1.5}
          minZoom={0.5}
          zoomStep={0.5}
          initialZoom={1}
          bindToBorders={true}

          style={{

          }}
        >
          <View style={{ flex: 1, justifyContent: "center" }}>
            <View style={{ alignItems: 'center' }}><Text style={{ fontSize: 30 }}>Content</Text></View>
            <Image style={{ width: null, height: '90%' }}
              source={require('./img/2R.jpg')}
              resizeMode="stretch" />
            <View style={{ alignItems: 'center' }}><Text style={{ fontSize: 30 }}>Content</Text></View>
          </View>
        </ReactNativeZoomableView>
      </View>
    );
  }
}

reference:
https://github.com/DuDigital/react-native-zoomable-view
https://wall.alphacoders.com/big.php?i=953683

Saturday, 26 October 2019

react native swiper horizontal






React native doesn't have any transform origin property yet. have to use translate to move rotation center to top left corner of screen, After rotation is done, shift view again to cover screen.

import React, { Component } from 'react'
import { Dimensions, ImageBackground, StyleSheet, Text, View } from 'react-native'
import Swiper from 'react-native-swiper'

const styles = StyleSheet.create({
  slide: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
  },
  text: {
    color: '#fff',
    fontSize: 30,
    fontWeight: 'bold'
  }
})

export default class SwiperComponent extends Component {
  constructor(props) {
    super(props);
    this.state = {
      height: null,
      width: null,
    };
  }

  componentWillMount() {
    //swap screen height and width after rotation
    let { height, width } = Dimensions.get('window');
    this.setState({
      width: parseInt(height),
      height: parseInt(width)
    })
  }

  render() {

    console.log(this.state.height, this.state.width)
    return (

      <View style={{
        height: this.state.height,
        width: this.state.width,
        translateX: -this.state.width / 2,
        translateY: -this.state.height / 2,
        transform: [{ rotate: '90deg' }],
        top: this.state.width / 2,
        left: this.state.height / 2,
      }}>

        <Swiper showsButtons={true}>
          <ImageBackground source={require('./img/1.jpg')}
            resizeMode='stretch'
            style={{ ...styles.slide, width: '100%', height: '100%' }}>
            <Text style={styles.text}>Hello Swiper</Text>
          </ImageBackground>
          <ImageBackground source={require('./img/2.jpg')}
            resizeMode='stretch'
            style={{ ...styles.slide, width: '100%', height: '100%' }}>
            <Text style={styles.text}>Beautiful</Text>
          </ImageBackground>
          <ImageBackground source={require('./img/3.jpg')}
            resizeMode='stretch'
            style={{ ...styles.slide, width: '100%', height: '100%' }}>
            <Text style={styles.text}>And Simple</Text>
          </ImageBackground>
        </Swiper>
      </View>
    )
  }
}


reference:
https://chuanshuoge2.blogspot.com/2019/10/react-native-swiper.html
https://stackoverflow.com/questions/46303736/make-dimension-relative-to-another-in-react-native
https://stackoverflow.com/questions/35050774/how-can-i-make-text-vertical-rotated-90-deg-in-react-native
https://stackoverflow.com/questions/52561376/react-native-transform-origin

react native swiper




npm i react-native-swipe

import React, { Component } from 'react'
import { ImageBackground, StyleSheet, Text, View } from 'react-native'
import Swiper from 'react-native-swiper'

const styles = StyleSheet.create({
  wrapper: {},
  slide: {
    justifyContent: 'center',
    alignItems: 'center',
  },
  text: {
    color: '#fff',
    fontSize: 30,
    fontWeight: 'bold'
  }
})

export default class SwiperComponent extends Component {
  render() {
    return (
      <Swiper style={styles.wrapper} showsButtons={true}>
        <ImageBackground source={require('./img/1.jpg')}
          resizeMode='cover'
          style={{ ...styles.slide, width: '100%', height: '100%' }}>
          <Text style={styles.text}>Hello Swiper</Text>
        </ImageBackground>
        <ImageBackground source={require('./img/2.jpg')}
          resizeMode='cover'
          style={{ ...styles.slide, width: '100%', height: '100%' }}>
          <Text style={styles.text}>Beautiful</Text>
        </ImageBackground>
        <ImageBackground source={require('./img/3.jpg')}
          resizeMode='cover'
          style={{ ...styles.slide, width: '100%', height: '100%' }}>
          <Text style={styles.text}>And Simple</Text>
        </ImageBackground>
      </Swiper>
    )
  }
}


reference:
https://github.com/leecade/react-native-swiper
https://github.com/leecade/react-native-swiper/blob/master/examples/components/Swiper/index.js
https://facebook.github.io/react-native/docs/images.html#background-image-via-nesting

设计师把家变成了魔方

Thursday, 24 October 2019

react native swipe list



swipe to show hidden features

npm install --save react-native-swipe-list-view

import React, { useState } from 'react';
import { FlatList, StyleSheet, Text, View } from 'react-native';
import { SwipeRow } from 'react-native-swipe-list-view';

export default function App() {
  const [data, setData] = useState(
    [{ text: 'Swipe Row #1', left: 'Left 1', right: 'Right 1', key: '1' },
    { text: 'Swipe Row #2', left: 'Left 2', right: 'Right 2', key: '2' },
    { text: 'Swipe Row #3', left: 'Left 3', right: 'Right 3', key: '3' },
    ]
  )
  return (
    <View style={styles.container}>
      <FlatList
        data={data}
        renderItem={({ item }) =>
          <View style={styles.standalone}>
            <SwipeRow leftOpenValue={75} rightOpenValue={-75}>
              <View style={styles.standaloneRowBack}>
                <Text style={styles.backTextWhite}>{item.left}</Text>
                <Text style={styles.backTextWhite}>{item.right}</Text>
              </View>
              <View style={styles.standaloneRowFront}>
                <Text>{item.text}</Text>
              </View>
            </SwipeRow>
          </View>
        }
      ></FlatList>
    </View>
  )
}

const styles = StyleSheet.create({
  container: {
    backgroundColor: 'white',
    flex: 1,
    marginTop: 25,
  },
  standalone: {
    marginVertical: 10,
  },
  standaloneRowFront: {
    alignItems: 'center',
    backgroundColor: '#CCC',
    justifyContent: 'center',
    height: 50,
  },
  standaloneRowBack: {
    alignItems: 'center',
    backgroundColor: '#8BC645',
    flex: 1,
    flexDirection: 'row',
    justifyContent: 'space-between',
    padding: 15,
  },
  backTextWhite: {
    color: '#FFF',
  },
});

reference:
https://www.npmjs.com/package/react-native-swipe-list-view
https://snack.expo.io/@jemise111/react-native-swipe-list-view

Tuesday, 22 October 2019

react native swipe










swipe direction up -> up -> right -> right-> down -> down -> left -> left
onSwipe is trigger on swipe, it receives the swipe direction from last swipe, so background color change lags the current swipe.

npm i -S react-native-swipe-gestures

import React, { Component } from 'react';
import { View, Text, StyleSheet } from 'react-native';
import GestureRecognizer, { swipeDirections } from 'react-native-swipe-gestures';

class SomeComponent extends Component {

  constructor(props) {
    super(props);
    this.state = {
      myText: 'I\'m ready to get swiped!',
      gestureName: 'none',
      backgroundColor: '#fff',
      direction: null,
    };
  }

  onSwipeUp(gestureState) {
    this.setState({ myText: 'You swiped up!', direction: swipeDirections.SWIPE_UP });
  }

  onSwipeDown(gestureState) {
    this.setState({ myText: 'You swiped down!', direction: swipeDirections.SWIPE_DOWN });
  }

  onSwipeLeft(gestureState) {
    this.setState({ myText: 'You swiped left!', direction: swipeDirections.SWIPE_LEFT });
  }

  onSwipeRight(gestureState) {
    this.setState({ myText: 'You swiped right!', direction: swipeDirections.SWIPE_RIGHT });
  }

  onSwipe(gestureName, gestureState) {
    const { SWIPE_UP, SWIPE_DOWN, SWIPE_LEFT, SWIPE_RIGHT } = swipeDirections;
    this.setState({ gestureName: gestureName });
    switch (gestureName) {
      case SWIPE_UP:
        this.setState({ backgroundColor: 'red' });
        break;
      case SWIPE_DOWN:
        this.setState({ backgroundColor: 'green' });
        break;
      case SWIPE_LEFT:
        this.setState({ backgroundColor: 'blue' });
        break;
      case SWIPE_RIGHT:
        this.setState({ backgroundColor: 'yellow' });
        break;
    }
  }

  render() {

    const config = {
      velocityThreshold: 0.3,
      directionalOffsetThreshold: 80
    };

    return (
      <View style={{ marginTop: 25, flex: 1 }}>
        <GestureRecognizer
          onSwipe={() => this.onSwipe(this.state.direction)}
          onSwipeUp={() => this.onSwipeUp()}
          onSwipeDown={() => this.onSwipeDown()}
          onSwipeLeft={() => this.onSwipeLeft()}
          onSwipeRight={() => this.onSwipeRight()}
          config={config}
          style={{
            flex: 1,
            backgroundColor: this.state.backgroundColor,
          }}
        >
          <Text style={styles.font}>{this.state.myText}{"\n"}</Text>
          <Text style={styles.font}>onSwipe callback received gesture: {this.state.gestureName}</Text>
        </GestureRecognizer>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  font: {
    fontSize: 30
  }
})

export default SomeComponent;

reference:
https://www.npmjs.com/package/react-native-swipe-gestures

Monday, 21 October 2019

react native scroll

<ScrollView>

<ScrollView horizontal>

<ScrollView pagingEnabled>

ScrollView works best to present a small amount of things of a limited size. All the elements and views of a ScrollView are rendered, even if they are not currently shown on the screen. If you have a long list of more items than can fit on the screen, you should use a FlatList instead.

import React, { Component } from 'react';
import { ScrollView, Image, Text } from 'react-native';

export default class IScrolledDownAndWhatHappenedNextShockedMe extends Component {
  render() {
    return (
      <ScrollView pagingEnabled>
        <Text style={{ fontSize: 96 }}>Scroll me plz</Text>
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Text style={{ fontSize: 96 }}>If you like</Text>
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Text style={{ fontSize: 96 }}>Scrolling down</Text>
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Text style={{ fontSize: 96 }}>What's the best</Text>
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Text style={{ fontSize: 96 }}>Framework around?</Text>
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Image source={{ uri: "https://facebook.github.io/react-native/img/tiny_logo.png", width: 64, height: 64 }} />
        <Text style={{ fontSize: 80 }}>React Native</Text>
      </ScrollView>
    );
  }
}

---------------------------------------

FlatList works well for long lists of data, where the number of items might change over time. FlatList only renders elements that are currently showing on the screen, not all the elements at once.

import React, { Component } from 'react';
import { FlatList, StyleSheet, Text, View } from 'react-native';

export default class FlatListBasics extends Component {
  render() {
    return (
      <View style={styles.container}>
        <FlatList
          data={[
            { key: 'Devin' },
            { key: 'Dan' },
            { key: 'Dominic' },
            { key: 'Jackson' },
            { key: 'James' },
            { key: 'Joel' },
            { key: 'John' },
            { key: 'Jillian' },
            { key: 'Jimmy' },
            { key: 'Julie' },
            { key: 'Alice' },
            { key: 'Don' },
            { key: 'Frank' },
            { key: 'Gorge' },
            { key: 'Harry' },
            { key: 'Kim' },
            { key: 'Lucy' },
            { key: 'Mary' },
            { key: 'Nancy' },
            { key: 'Obama' },
          ]}
          renderItem={({ item }) => <Text style={styles.item}>{item.key}</Text>}
        />
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    paddingTop: 22
  },
  item: {
    padding: 10,
    fontSize: 18,
    height: 44,
  },
})

----------------------------------------
import React, { Component } from 'react';
import { SectionList, StyleSheet, Text, View } from 'react-native';

export default class SectionListBasics extends Component {
  render() {
    return (
      <View style={styles.container}>
        <SectionList
          sections={[
            { title: 'D', data: ['Devin', 'Dan', 'Dominic'] },
            { title: 'J', data: ['Jackson', 'James', 'Jillian', 'Jimmy', 'Joel', 'John', 'Julie'] },
            { title: 'V', data: ['Victor', 'Vince', 'Vincent', 'Vladimir', 'Vermon', 'Vito', 'Vinson'] },
          ]}
          renderItem={({ item }) => <Text style={styles.item}>{item}</Text>}
          renderSectionHeader={({ section }) => <Text style={styles.sectionHeader}>{section.title}</Text>}
          keyExtractor={(item, index) => index}
        />
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    paddingTop: 22
  },
  sectionHeader: {
    paddingTop: 2,
    paddingLeft: 10,
    paddingRight: 10,
    paddingBottom: 2,
    fontSize: 14,
    fontWeight: 'bold',
    backgroundColor: 'rgba(247,247,247,1.0)',
  },
  item: {
    padding: 10,
    fontSize: 18,
    height: 44,
  },
})

Sunday, 20 October 2019

炒股的境界

第一级:初战告捷,豪气冲天。


新股民,有了一点闲钱,不屑于银行的低利率,想在股市里“钱生钱”,于是像模像样的开了户,此时对股票交易规则、股市运行规律、股市术语、技术指标等知之甚少或完全不知,这个时候的买卖很随意,仅凭感觉,盈亏全靠运气。

这个时候的表现更多的是好奇、兴奋,也比较虚心,能够虚心像周围的人请教,准备在股市上大干一场。这个时候运气往往不错,大多会赚一些小钱,很多人会因此感叹原来在股市赚钱这么容易。赚钱的主要原因恰恰是心态比较单纯,就像刚出生的婴儿。

第二级:迷信专家,上当受骗。


轻松赚到小钱之后,开始加大投入股市的资金,炒股的知识也比以前懂的多了,知道一些证券基本常识和简单的技术指标,幻想在股市发大财,殊不知这个时候厄运却悄悄来临。在度过初入股市的一段兴奋期后,但懂的多了,却不赚钱了,此时才发觉在股市投资赢利并非想象中的容易。

发现炒股还真的不简单之后,往往变成自己拿不定主意却喜欢盲目跟风操作的投资者。往往会轻信老股民,尤其迷信各类股评、“专家”和知名博客,成为其忠实的追随者,并且爱打听所谓的内幕消息。经常关注各类媒体的股评文章或电视广播里的股评节目,也是各类股评报告会的常客。天真的期盼股评人士为自己的股票投资出谋划策,但最终结果多是失望大于希望。

这个时候的操作毫无主见,别人怎么说就怎么做,像无头的苍蝇那样乱撞。喜欢跟热点,盲目跟风并短线操作,以为这样才安全。操作上带有很大的盲目性和随意性,自然成为庄家拉高出货,打压吸筹的牺牲品。亏钱很容易,赚钱很难。

第三级:价值分析,镜中花水里月。


太多次的轻信、受骗之后,不敢再盲目相信别人了,求人不如求己,但这个时候往往对技术分析知之甚少,一般会开始热衷研究上市公司基本面、政策面,也就是所谓的基本面和价值分析。但公司基本面受管理者水平、上下游行业景气度、国内、国际政治、经济形势,甚至是股市大市环境影响巨大,一般投资者很难探寻究竟,而公司财务数据作假严重,不可轻信。

大盘顶部,基本面所有的消息都是好的,还有人给你描画美好蓝图,相信基本面只会让你在高位站岗;大盘底部,基本面所有的消息都是坏的,还有人给你自残的理由,相信相信基本面只会增强你认赔卖出的勇气;在股市的大底部和大顶部,你只能反着做,否则你将死的很惨,但反着做的理由别人给不了你,基本面给不了你,只有通过自己的研究,在技术面中寻找蛛丝马迹。

迷恋基本面和价值分析,其实也是外道。虽然这方面最让人激动的榜样就是“股神”巴菲特,让一大批人趋之若鹜。其实,价值投资不是不好,而是投资价值需要专业的投资价值分析和细致完善的实地考察、市场调查手段,这方面机构、大资金更有优势,另外,巴菲特并非简单的价值投资,其盈利模式更适合机构、大资金而不是散户,相对于技术分析的直观、高效,散户根本不具备有效价值分析的能力,在此基础上大谈价值投资无异于天方夜谭。

在基本面和价值分析的结果和市场真实走势出现巨大的反差甚至恰好相反的问题时,常常不知所措,价值分析成为镜中花、水中月,可望而不可及。而在基本面分析方法不灵时,又只得求助于技术分析方法。

第四级:苦练技术,屡战屡败。


在价值分析上碰壁之后,意识到只有不断的提高自己的技能才能立于不败之地,于是开始刻苦用功,努力学习各种知识和操作技巧。开始迷恋研究技术指标或某种技术分析方法,但一知半解,对股市渐渐有了自己的认识,但不清晰,也不太准确。

由于股票的技术包罗万象,太多、太活。有些人在刚弄懂几个技术分析指标、形态或方法(一知半解),就认为翅膀已硬,自以为懂了很多,好为人师,喜欢评论股票,想当然的成分居多,所以成功率并不高。仍然亏钱,主要原因---- 知道一点比不知道还糟。

这个时候的操作,有时短线、有时长线,试过各种方法,有时赚,有时亏,经常坐过山车,到头来都是纸上富贵。懂得越来越多,资金越来越少,信心越来越小。失败的原因在于技术指标只是概率,而且永远滞后于行情,试图用某一个技术指标或某一种技术分析方法预测行情,根本就是一个伪命题。如果你希望把这个根本不可能的事情变成现实,现实当然总是白费力气。

这个阶段的结果,要么走入死胡同,陷入外道,要么彻底对技术绝望,沦为技术无用论。

第五级:迷惘轮回,股海无边。多数散户的最终归宿。


学习了各种知识,经历过各种行情,经过了大涨大跌,试过各种各样的方法,但处处碰壁,吃过各种苦头,怎么努力都不见提高,钱赚了又赔掉,或者越来越少,即使赚,也不太多,而且很辛苦,陷入非常迷惘的状态,好像是处在一个陷阱或者重重迷雾之中,看不见进步,也看不到希望,也不知道何时能够走出。

这个时候,股市好像总是跟自己作对,信基本面基本面也是假的,信技术时技术无用,不信技术时技术反而管用。别人不可信,自己没自信,技术不可信,价值不可信,看什么都不对,怎么做都是错的。更可气的是这个时候发现原来网络、电视、媒体上的专家、都是大忽悠,周围“高手”的情况其实也和自己差不了多少,信心低落到了极点。

现在,股市在你眼里已经不再是刚开始时“遍地是黄金”的感觉,反而发现是遍地都是陷阱。股市是一个没有标准答案的地方,只要想说,谁都可以发表自己的意见,听起来也都象那么回事,所以,股票市场里充满了一知半解和盲人摸象式的评论。同时,股市又是一个金钱的角斗场,一些心怀叵测的人为了利益不择手段,股市里也就充满了谎言和欺骗。

许多人会困惑,为什么刚开始炒股时什么都不懂的情况下还能赚到钱?真的只是初生牛犊不怕虎的精神吗?显然不是。真正的原因恰恰是把简单的问题搞复杂了。所以,一般人很容易被陷入其中,不能自拔。大部分人都会先后进入这个阶段,而且遗憾的是,超过80% 的人一直会停留在这个层次中,永远也不会走出,有的会重新回到第二、三、四级的阶段去,堕入苦海轮回,不能解脱。有些人也许会因为彻底失望而退出股市。

这个过程,别人帮不了你,你只有自己帮助自己。

第六级:技高一筹,风光无限。常见高手的最高境界。


有少部分悟性较高的投资者,一般是有较长股龄、经验丰富的老股民,在实战积累的基础上融合各种理论形成了一套独特的、完整的、适合自己风格的交易系统或操作体系,并且能够把它们运用得得心应手。也有一些人,能够熟练的应用某一项技术,赚钱概率较高,或者有的掌握了某种绝招,也能做到亏少赢多,进入一般人难以企及的高手行列。

由于股票技术没有权威的标准,只要想说,任何人都可以发表自己的看法,这个阶段的人尤其喜欢说话,期望获得别人的承认,喜欢预测和向别人推荐股票。有道是“一瓶子不满,半瓶子晃荡。”事实上是越不懂的人越喜欢说,所以,市场里的声音更多是“半瓶醋”贩卖的盲人摸象、自以为是的言论,让人眼花缭乱。

很多人的自我感觉相当不错,但表面上风光无限的背后,他们应该知道钱赚的并不轻松,赚钱的概率并不如想象的那样高,盈利幅度也不是很高,正所谓如人饮水,冷暖自知。这种状况会持续很长的时间,技术也很难再有突破和提高。仍然会经常止损,而且感到痛苦,具体多长取决于你的悟性和努力。原因就在于此时并没有找到投资的真理,理念和技术上都还有缺陷,所以仍然会遇到许多不能解决的问题。

这一级是一般高手所能达到的最高境界,能够到达这一级的人不会很多,比例不会大于10%,一般常见的高手绝大部分属于这个级别,这里面当然也有层次高低的区别,限于篇幅,不再细分。同样遗憾的是,他们中的大部分一般也会终生停留在这个层次,

这种的局面比上一级更难打破,除非有悟性、真正谦虚的人,某一天恍然醒悟,开始重新审视股市和自己,能够认识到自己的不足,并下决心战胜自己,回归简单、轻装上阵的时候,你才能象更高的目标进发。

第七级:为道日损,有舍有得。向更高目标迈进的必经之路。


炒股是个系统工程,理念、技术、心态,短了哪一个都不能成功。技术和心态相辅相成,离开任何一个,都是妄谈、扯淡!这就是许多人努力了很多也不能成功的主要原因。理念尤其重要,因为理念是方向,勤奋是必要的,但如果方向不对,就成了南辕北辙,到头来自然白费力气。

这一级要做的就是确立正确的方向,就是化繁为简的过程。只有少数人能意识到是理念出了问题,也就是走错了努力的方向,开始探寻正确的理念,有针对性的潜心研究技术,开始学会放弃那些花里胡哨的东西,不再听股评,不再听消息、也不再听假高手意淫的鼓噪;不再和市场去拼命,也不再奢谈战胜庄家,知道天外有天,人外有人,不再盲目自大,知道首要要战胜的是自己;放弃短线,择选中线波段,学着看大盘做个股。

这个阶段结束的标志是理念的成熟和技术的化繁为简。最接近于“道”的理念应该是:以技术分析为主、基本面分析为辅,中线波段为主、适长则长适短则短,看大盘炒个股。牛市满仓赚钱,熊市空仓赚股。技术呢,是在道琼斯理论指导下,以均线为主,以趋势线、形态分析为辅,并参考成交量、KDJ、MACD、BIAS等几个最常用的辅助指标。

此时,你已知道预测是不对的,但你还是喜欢预测,虽然你的预测得到验证的概率越来越高,但有时难免会犯一些小错误。在旧的技术体系打破之后,新的技术体系还没有建立之前,有些人往往会出现因为偶然失误导致大幅亏损甚至是赔光了的惨痛经历,这就是“体验风险阶段”。不要怕,这也许是你大成之前的最后考验,也许是必须的,请千万不要放弃。

这一级是基础,只有过了这一级,你才有可能向更高的目标迈进。后面的级别和前面的级别的不同,前面的级别,因为个性和悟性的不同,不同的人会有不同的通过方式,各个级别或有跨越,或有反复,而后面的级别,必须一级一级的过,而且更加漫长。

悟道很难,如果你始终不能觉悟,但还想进步,还想继续提高自己赚钱的能力,我可以告诉你一个变通的方法:你做不到化繁为简,但你可以做到相信简,你如果还没做到,或者对以上说法还有疑问,我可以肯定的告诉你,你还没有通过这一级。

第八级:浴火重生,脱胎换骨。化繁为简之后的再超越。


需要顿悟,也需要渐修。找到正确的投资理念和最简单有效的技术,还只是新的起点,后面的路还很长。从下决心这样做,到真的很自然的这样做,再到自己摸索出适合自己风格的交易系统或操作体系,其间都会有一个艰苦磨练的过程。才能把自己总结出的技术融会贯通、熟能生巧,技术和心态才都趋于成熟。

在大势上升的时候,个股操作的成功率提高很多,只是存在赚多赚少的问题,你会发现自己已经很长时间不再赔钱了。在大势不好的时候,会及时撤出休息,虽然这时有些无所事事,感到寂寞,仍有再次冲进去的冲动,但已知道空仓是必要的,也能管住自己的手了。顺势而为更加得心应手,对买入卖出点的把握更加精确,但仍有些偏差,需要依靠超乎常人的忍耐避免技术上的不足,困惑已不多,但仍感觉到痛苦。

此时使用的技术不再象从前那么多,但也因此避免了因使用多种技术而结论不一致导致无所适从的尴尬,可靠性反而增强了很多,头脑更清晰了,自信心更足了,根据技术面的结果,结合政策面、个股基本面、资金面、投资者心理等多方面的分析,综合分析之后,虽然不再预测,但对行情却越来越有感觉,对股市的整体走势判断越来越准确。

理念定型之后,找到了正确的方向,找到了最关键的技术,进步很快并取得突破。这个时候,你的身心都已经发生巨大的转变,虽然你的理念和技术已经今非昔比,赚钱越来越容易了,但你却甘于寂寞,不再喜欢卖弄了。你已经清醒的知道,炒股只是在正确的时间做正确的事,赚钱是副产品,是一种奖励,是你本来就应该得到的。

技术分析的三大假设之一是市场行为包容消化一切信息。此时,完全依靠技术就可以获利,你更相信技术了,此前我们常听到的一句口头禅是:“技术分析不是万能的,但是不学技术是万万不能的。”现在这个时候你会明白,这句话是多么的浅薄,这只是没学好技术时的一句自我安慰的话,以前技术失效的主要原因在于用错了技术或者技术不到家,这不是技术的错,而是当时技术分析的能力不足。现在你做到了仅仅凭借高超技术就可以稳定的赚钱,从这个意义上来说,技术的确是万能的。

这一级最大的特征是开始放弃预测,而是知道趋势才是最重要的,知道顺势而为的重要性,也理解了有所为有所不为。不再预测,更重视规则,然后在规则的指导下对过去和现在的走势做相对客观的评估,并分析未来可能的走势同时做好应变的计划。炒作股票看重成功的概率,没有把握绝不轻易出手,忍受着寂寞,时机一到,出手不凡,则必定做到“稳、准、狠”。

成功标志:从此再不愿评股,更知道每一战都异常艰辛,胜负的关键更多在细微之处。如果有人问你明天如何?你会很认真的说:“明天股市肯定波动!”


第九级:人股合一,道法自然。技术的最高境界。均线舞者,趋势之王。“无招胜有招,摘叶当飞镖!”


技术分析的三大假设之二是价格呈趋势变动,这是进行技术分析最根本、最核心的因素。而最直观和最有效的反映趋势的指标就是均线和趋势线,经过国外股市200 年左右的积淀,趋势线已经是一种成熟的技术,但是均线只是在微型计算机大规模应用和普及之后才出现的,在此之前由于计算的繁复,使之成为不可能的事情,更不用谈能有什么完善的均线理论了。只有随着电脑的普及和均线的普遍运用,均线理论的创新和超越才成为可能。

现在,我们可以坚信,真正的技术上的突破一定是在均线使用方式、方法上的突破。均线理论才是最接近于道、最能反映顺势而为理念的理论。可惜的是,迄今为止,均线的普遍应用最多不超过30 年的时间,所以,不管是国内还是国外,目前都还没有公开的成熟的均线理论。但这也使我们得以站在和西方发达国家同一个起跑线上,有志于此的朋友们,我们应该自觉的肩负起均线理论的创新和超越的重任!

武术的最高境界是:“无招胜有招,摘叶当飞镖!”说得是到了无招的境界,随便拿什么都可以当武器。其实,做股票何尝不是如此?我们需要的应该是类似李小龙“截拳道”那样最有效、最直接的盈利模式。均线是最普通、最常见的、任何一个哪怕是最简单的免费软件都有的指标,但在你眼里均线已经不是常人眼里的模样,不需要在参数上纠缠,不需要过多的修饰,只要均线在你眼前,你很清楚趋势在什么状态,正常不正常。不仅如此,即使你不用均线,用最普通的KDJ和MACD,也能达到同样的效果,但你的用法和其他人截然不同,你不再关注是否金叉死叉,也不在关心红柱绿柱的长短,但却更加可靠有效,其他任何一个指标也能达到同样的效果。

此时,你对股市的波动运行方向的把握相当准确,高屋建瓴笑看风云,如行云流水一般的洒脱。遵守规则时不再痛苦,而成为自觉的行动、自然的反应,真正能做到“手中有股,心中无股;”“不以涨喜,不以跌悲”,顺势而为,知行合一,自然而然,随心所欲,到达“无招胜有招摘叶当飞镖”的境界。

趋势越来越清晰,现在看股市,你会突然发现自己有了洞若观火的感觉,仿佛戴了一个透视眼镜,每在关键时刻,你都可以看见主力机构或庄家的身影,以前认为他们是刻意为之,现在看来他们也许是不得已。看股市众生,也越来越明白。你能看出高手的缺陷和所处的状态,知道大多数斩钉截铁的评论不过是盲人摸象的胡话而已,因为你自己经历过那时的状态;你能知道政策的真实意图,因为你曾经站在管理层的角度思考过同样的问题。你知道什么样的话是真话,什么样的是假话,什么样的话是无可奈何的,什么样的话是身不由己的。

炒股不再是技术,而是一种艺术。在你眼里,股市的一切都是自然现象,违背自然规律必然就会受到它的惩罚股市开始具有生命力,好股票的走势具有天然的美感,股价的起伏就像在均线之间跳舞,而你感觉自己的舞姿越来越越优美了

到达这一级非常不容易,很早就看到一篇文章,说炒股如修行,知道应该是这样,但当时没有多少真切的感受,经过十多年的磨练才知道,这句话一点都不假;修行真的不容易,智慧如释迦牟尼佛者,在菩提树下“悟道”之前,也经过了 12 年的外道修行,其实,佛祖在这 12 年当中只做了一件事,就是“知非即舍”,意思就是知道不是道就舍弃了。所以,我等肉眼凡胎,在炒股中吃点苦头,真的不算什么。

大家都知道爱迪生成功发明电灯之前经历了了 7000 多次失败,这一点,我深有感触。我在黑暗中摸索的时候,常常对朋友感慨:我不是在炒股,而是象做学问一样研究股票,这个过程和爱迪生发明电灯一样的艰难。股票的技术很多,从什么都学习研究,到最后几乎全部放弃,均线的技术很活,从认准均线到悟到神奇的均线理论,期间的艰辛绝不亚于爱迪生发明电灯的过程。

第十级:超然股外,功德圆满。技术和人性的双重圆满。已称得上世外高人,无为无不为。


技术出神入化,心态宠辱不惊,无为无不为,纵情山水,超然物外。股如人生,人生亦股,人性和股性都到达圆满的境界,从此看透股市,参悟人生,接近于“股神”的境地。

尽管你每次战斗都谨小慎微,但你的实际成功率确是非常的高。股市就像一个你非常熟悉的朋友或情人,你可以感到它的呼吸,它的心跳。每天看盘,它都会对你窃窃私语,这是一种灵魂上的沟通,以至于你无法用清晰的语言来向别人说明,如果你尽力说,人们就会认为你是精神病,实际大家的看法也没错,股市本来就是精神病。熟悉你的人认为你很神奇,你的每次操作对他们来说有种惊天动地的感受,而对你来说,什么也不是,你非常平静,你只是认为应该这样做,甚至在操作时,你什么也没想,只是灵机一动就做了,但却经常胜利。这时你会有机会操作大资金,如果作庄,你控筹相对少,但盘面却控制的更理想,拉升时也是用的资金少,高度却很高,出完了货,股价还要升一段,业内人看来不可思议,皆叹你有惊天动地之能。只有你自己知道,你不过是一粒尘土,何德何能?不过是顺天应人,偷天功为己有罢了。修练成功的标志,操作能做到天人合一,随心所欲,成功率却高于许多高手。

这个时候,在你的眼中,股市已经不再是原来的模样了,人生也已不再是过去的人生。你把它看成是人的一生,人类的历史,经济的起浮,万事的兴衰。此时你不仅知道股市会如何,你更知道人生会如何,社会会如何,对世间万物,你有种半仙的感觉,你可以看到自己的未来。因此,你会更敏感花开花落,云飞雾起,你会更感叹世态的炎凉,人间的劳苦。你会感受只有大自然才是最完美与和谐的,只有在山水间才能体会到生命的意义,才能得到心灵的平静。

reference:
https://zhuanlan.zhihu.com/p/36847555

react native touches

TouchableHighlight

TouchableOpacity

TouchableNativeFeedback

onLongPress

onPress

import React, { Component, useState } from 'react';
import {
  Platform, StyleSheet, Text, TouchableHighlight,
  TouchableOpacity, TouchableNativeFeedback, TouchableWithoutFeedback, View
} from 'react-native';

export default function TestBasics() {

  function _onPressButton() {
    alert('You tapped the button!')
  }

  function _onLongPressButton() {
    alert('You long-pressed the button!')
  }


  return (
    <View style={styles.container}>
      <TouchableHighlight onPress={() => _onPressButton()} underlayColor="white">
        <View style={styles.button}>
          <Text style={styles.buttonText}>TouchableHighlight</Text>
        </View>
      </TouchableHighlight>
      <TouchableOpacity onPress={() => _onPressButton()}>
        <View style={styles.button}>
          <Text style={styles.buttonText}>TouchableOpacity</Text>
        </View>
      </TouchableOpacity>
      <TouchableNativeFeedback
        onPress={() => _onPressButton()}
        background={Platform.OS === 'android' ? TouchableNativeFeedback.SelectableBackground() : ''}>
        <View style={styles.button}>
          <Text style={styles.buttonText}>TouchableNativeFeedback {Platform.OS !== 'android' ? '(Android only)' : ''}</Text>
        </View>
      </TouchableNativeFeedback>
      <TouchableWithoutFeedback
        onPress={() => _onPressButton()}
      >
        <View style={styles.button}>
          <Text style={styles.buttonText}>TouchableWithoutFeedback</Text>
        </View>
      </TouchableWithoutFeedback>
      <TouchableHighlight onPress={() => _onPressButton()} onLongPress={() => _onLongPressButton()} underlayColor="white">
        <View style={styles.button}>
          <Text style={styles.buttonText}>Touchable with Long Press</Text>
        </View>
      </TouchableHighlight>
    </View>
  );
}


const styles = StyleSheet.create({
  container: {
    paddingTop: 60,
    alignItems: 'center'
  },
  button: {
    marginBottom: 30,
    width: 260,
    alignItems: 'center',
    backgroundColor: '#2196F3'
  },
  buttonText: {
    textAlign: 'center',
    padding: 20,
    color: 'white'
  }
});


《侣行》第三季



Saturday, 19 October 2019

react native flex 2

<View style={{ flex: 1, flexDirection: 'column', marginTop: 25 }}>

<View style={{ flex: 1, flexDirection: 'column', alignItems: 'center', marginTop: 25 }}>

<View style={{ flex: 1, flexDirection: 'column',  flexWrap: 'wrap', marginTop: 25 }}>

<View style={{ flex: 1, flexDirection: 'column', flexWrap: 'wrap', 
alignContent: 'center', marginTop: 25 }}>

<View style={{ flex: 1, flexDirection: 'column', flexWrap: 'wrap', 
alignContent: 'stretch', marginTop: 25 }}>

<View style={{ flex: 1, flexDirection: 'column', flexWrap: 'wrap', 
alignContent: 'space-between', marginTop: 25 }}>

<View style={{ flex: 1, flexDirection: 'column', flexWrap: 'wrap', 
alignContent: 'space-around', marginTop: 25 }}>

import React, { Component, useState } from 'react';
import { StyleSheet, Text, View, Button } from 'react-native';
import useInterval from 'react-useinterval';

function PoolBall(props) {
  return (
    <View style={{ ...styles.ball, backgroundColor: props.color }} >
      <View style={{ flexDirection: 'row', justifyContent: 'center' }}>
        <View style={{ ...styles.number, backgroundColor: 'white' }}>
          <View style={{ flexDirection: 'row', justifyContent: 'center' }}>
            <Text>{props.label}</Text>
          </View>
        </View>
      </View>
    </View>
  )
}

function PoolBallStripe(props) {
  return (
    <View style={{ ...styles.ball, backgroundColor: 'lightgrey' }} >
      <View style={{ flexDirection: 'row', justifyContent: 'center' }}>
        <View style={{ ...styles.stripe, backgroundColor: props.color }}>
          <View style={{ flexDirection: 'row', justifyContent: 'center' }}>
            <View style={{ ...styles.number, backgroundColor: 'white' }}>
              <View style={{ flexDirection: 'row', justifyContent: 'center' }}>
                <Text>{props.label}</Text>
              </View>
            </View>
          </View>
        </View>
      </View>
    </View>
  )
}

export default function FlexDirectionBasics() {

  return (
    <View style={{ flex: 1, flexDirection: 'column', marginTop: 25 }}>

      <PoolBall color='yellow' label={1} />


      <PoolBall color='blue' label={2} />
      <PoolBall color='red' label={3} />


      <PoolBall color='violet' label={4} />
      <PoolBall color='orange' label={5} />
      <PoolBall color='green' label={6} />


      <PoolBall color='brown' label={7} />
      <PoolBall color='black' label={8} />
      <PoolBallStripe color='yellow' label={9} />
      <PoolBallStripe color='blue' label={10} />


      <PoolBallStripe color='red' label={11} />
      <PoolBallStripe color='violet' label={12} />
      <PoolBallStripe color='orange' label={13} />
      <PoolBallStripe color='green' label={14} />
      <PoolBallStripe color='brown' label={15} />

    </View>
  );
}


const styles = StyleSheet.create({
  ball: {
    width: 50,
    height: 50,
    borderRadius: 25,
    flexDirection: 'column',
    justifyContent: 'center',
    marginVertical: 25
  },
  number: {
    width: 20,
    height: 20,
    borderRadius: 10,
  },
  stripe: {
    width: 30,
    height: 50,
    borderRadius: 11,
    flexDirection: 'column',
    justifyContent: 'center'
  }
});

reference:
http://chuanshuoge2.blogspot.com/2019/10/react-native-flex.html