1.球员能力图
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties
font = FontProperties(fname=r'C:\Windows\Fonts\SIMSUN.ttc', size=12)
ability_label = [u'进攻', u'防守', u'盘带', u'速度', u'体力', u'射术']
ability_size = 6
player = {
'M': np.random.randint(size=ability_size, low=10, high=99),
'N': np.random.randint(size=ability_size, low=10, high=99),
'H': np.random.randint(size=ability_size, low=10, high=99),
'Q': np.random.randint(size=ability_size, low=10, high=99)
}
theta = np.linspace(0, 2 * np.pi, 6, endpoint=False)
theta = np.append(theta, theta[0])
player['M'] = np.append(player['M'], player['M'][0])
player['N'] = np.append(player['N'], player['N'][0])
player['H'] = np.append(player['H'], player['H'][0])
player['Q'] = np.append(player['Q'], player['Q'][0])
plt.style.use('ggplot')
ax1 = plt.subplot(221, projection='polar')
ax2 = plt.subplot(222, projection='polar')
ax3 = plt.subplot(223, projection='polar')
ax4 = plt.subplot(224, projection='polar')
def set_ax(ax, theta, player, p_name, color):
ax.fill(theta, player, color, alpha=0.3)
ax.set_xticks(theta)
ax.set_xticklabels(ability_label, y=-0.05, fontproperties=font)
ax.set_title(p_name, fontproperties=font, color=color, size=20)
ax.set_yticks([])
set_ax(ax1, theta, player['M'], '球员A', 'r')
set_ax(ax2, theta, player['N'], '球员B', 'g')
set_ax(ax3, theta, player['H'], '球员C', 'b')
set_ax(ax4, theta, player['Q'], '球员D', 'y')
plt.show()
2. 股票K线图
import os
import pandas as pd
import matplotlib.pyplot as plt
import mpl_finance as mpf
from pandas.plotting import register_matplotlib_converters
register_matplotlib_converters()
plt.style.use("ggplot")
datadir = 'yahoo-data'
fname = '002001.csv'
data = pd.read_csv(os.path.join(datadir, fname), index_col='Date', parse_dates=True)
vol = data['Volume']
left, width = 0.1, 0.8
rect_vol = [left, 0.1, width, 0.3]
rect_main = [left, 0.46, width, 0.5]
fig = plt.figure()
ax_vol = fig.add_axes(rect_vol)
ax_main = fig.add_axes(rect_main)
ax_vol.fill_between(vol.index, vol.values, color='y')
plt.setp(ax_vol.get_xticklabels(), rotation=30, horizontalalignment='right')
main_data = []
for d in data.reset_index().values:
d[0] = d[0].timestamp()
main_data.append((d[0], d[1], d[2], d[3], d[4]))
print(main_data)
mpf.candlestick_ohlc(ax_main, main_data, width=30000, colorup='r', colordown='g')
plt.xticks([])
plt.show()