豪在这学python 发表于 2024-5-27 09:33:31

实现数据可视化

在web页面实现各国经济的展示,以柱状图展示,展示数据数据库给出,数据库的内容自己编辑,展示的动图要有一定的科技感@fishc

豪在这学python 发表于 2024-5-30 18:57:46

@fish

FishC 发表于 2024-5-30 18:57:55

豪在这学python 发表于 2024-05-30 18:57
@fish

嗨!有什么问题或者困惑我可以帮助解答吗?编程初学者常常面临各种难题,无论是语法问题还是算法问题,只要你告诉我具体的问题,我会尽力给出易懂且幽默的解答。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 19:12:43

FishC 发表于 2024-5-30 18:57
嗨!有什么问题或者困惑我可以帮助解答吗?编程初学者常常面临各种难题,无论是语法问题还是算法问题, ...

"""数据可视化,歌单介绍词云图"""
from wordcloud import WordCloud, ImageColorGenerator
import matplotlib.pyplot as plt
import pandas as pd
import jieba
import time


def data_visualization_of_music_wordcloud():
    """歌单介绍词云图"""
    df = pd.read_csv('music_data/music_detail.csv', header=None)
    text = ''

    print("正在生成歌单介绍词云图片...")

    # 输出进度条
    t = 60
    start = time.perf_counter()

    for i in range(t + 1):
      finsh = "▓" * i
      need_do = "-" * (t - i)
      progress = (i / t) * 100
      dur = time.perf_counter() - start

      print("\r{:^3.0f}%[{}->{}]{:.2f}s".format(progress, finsh, need_do, dur), end="")

      time.sleep(0.02)

    for line in df:
      text += ' '.join(jieba.cut(line, cut_all=False))

    background_image = plt.imread('music_image/img/background_image.jpg')

    stopwords = set('')
    stopwords.update(
      ['封面', 'none介绍', '介绍', '歌单', '歌曲', '我们', '自己', '没有', '就是', '可以', '知道', '一起', '不是',
         '因为', '什么', '时候', '还是', '如果', '不要', '那些', '那么', '那个', '所有', '一样', '一直', '不会', '现在',
         '他们', '这样', '最后', '这个', '只是', '有些', '其实', '开始', '曾经', '所以', '不能', '你们', '已经', '后来',
         '一切', '一定', '这些', '一些', '只有', '还有'])

    wc = WordCloud(
      background_color='white',
      mask=background_image,
      font_path='./font_resources/STZHONGS.ttf',
      max_words=2000,
      max_font_size=150,
      random_state=30,
      stopwords=stopwords
    )
    wc.generate_from_text(text)

    # 看看词频高的有哪些,把无用信息去除
    process_word = WordCloud.process_text(wc, text)
    sort = sorted(process_word.items(), key=lambda e: e, reverse=True)
    # print(sort[:50])

    img_colors = ImageColorGenerator(background_image)
    wc.recolor(color_func=img_colors)
    plt.imshow(wc)
    plt.axis('off')

    # 保存图片
    wc.to_file("./music_image/music_wordcloud.png")

    # 显示图片
    plt.show()

    print("\n已生成歌单介绍词云图片,保存至 music_image/music_wordcloud.png")
解释代码,给上注释

FishC 发表于 2024-5-30 19:13:55

豪在这学python 发表于 2024-05-30 19:12
"""数据可视化,歌单介绍词云图"""
from wordcloud i ...

这段代码实现了一个歌单介绍词云图的数据可视化。下面我将对代码进行解释,并给出一些注释。

"""数据可视化,歌单介绍词云图"""
from wordcloud import WordCloud, ImageColorGenerator
import matplotlib.pyplot as plt
import pandas as pd
import jieba
import time

def data_visualization_of_music_wordcloud():
    """歌单介绍词云图"""
    df = pd.read_csv('music_data/music_detail.csv', header=None)
    text = ''

    print("正在生成歌单介绍词云图片...")

    # 输出进度条
    t = 60
    start = time.perf_counter()

    for i in range(t + 1):
      finsh = "■" * i
      need_do = "□" * (t - i)
      progress = (i / t) * 100
      dur = time.perf_counter() - start

      print("\r{:^3.0f}% |{}{}| {:.2f}s".format(progress, finsh, need_do, dur), end="")

      time.sleep(0.02)

    for line in df:
      text += ' '.join(jieba.cut(line, cut_all=False))

    background_image = plt.imread('music_image/img/background_image.jpg')

    stopwords = set('')
    stopwords.update([])

    wc = WordCloud(
      background_color='white',
      mask=background_image,
      font_path='./font_resources/STZHONGS.ttf',
      max_words=2000,
      max_font_size=150,
      random_state=30,
      stopwords=stopwords
    )
    wc.generate_from_text(text)

    # 看看词频高的有哪些,把无用信息去除
    process_word = WordCloud.process_text(wc, text)
    sort = sorted(process_word.items(), key=lambda e: e, reverse=True)
    # print(sort)

    img_colors = ImageColorGenerator(background_image)
    wc.recolor(color_func=img_colors)
    plt.imshow(wc)
    plt.axis('off')

    # 保存图片
    wc.to_file("./music_image/music_wordcloud.png")

    # 显示图片
    plt.show()

    print("\n已生成歌单介绍词云图片,保存至 music_image/music_wordcloud.png")

1. 导入了所需的库,包括WordCloud(词云图生成库)、ImageColorGenerator(用于为词云图上色)、matplotlib.pyplot(用于显示和保存图像)等。
2. `data_visualization_of_music_wordcloud()`是一个函数,表示生成歌单介绍词云图。
3. 打开了一个CSV文件(`music_data/music_detail.csv`),将其中的数据读取到一个`DataFrame`(`df`)中。
4. 通过使用`jieba`库,将歌单介绍进行分词并拼接成一个长文本(`text`)。
5. 加载背景图片(`background_image`)。
6. 定义了一个停用词集合(`stopwords`),用于过滤一些常见的无意义词汇。
7. 创建了一个`WordCloud`对象(`wc`),设置了各种参数,如背景颜色、字体路径、最大词数等。
8. 通过调用`generate_from_text()`方法,将处理好的文本生成词云图。
9. 处理生成的词云图,通过定义图片颜色生成器(`img_colors`),为词云图上色。
10. 使用`imshow()`方法,显示词云图,并关闭坐标轴。
11. 调用`to_file()`方法,将生成的词云图保存到本地(`./music_image/music_wordcloud.png`)。
12. 调用`show()`方法显示词云图。
13. 最后输出提示信息,表明词云图生成成功并保存在指定路径下。

希望以上解释对你有帮助,如果还有其他问题,欢迎继续提问!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 19:31:54

FishC 发表于 2024-5-30 19:13
这段代码实现了一个歌单介绍词云图的数据可视化。下面我将对代码进行解释,并给出一些注释。




我想用python对数据库中的数据进行可视化,将数据库中的数据以柱状图的形式呈现,如何完成代码?

FishC 发表于 2024-5-30 19:32:07

豪在这学python 发表于 2024-05-30 19:31
我想用python对数据库中的数据进行可视化,将数据库中 ...

要使用Python对数据库中的数据进行可视化,你可以使用以下步骤完成代码:

1. 首先,你需要安装所需的库。这里推荐使用`pandas`用于数据处理和`matplotlib`用于数据可视化。你可以使用以下命令安装它们:

    pip install pandas matplotlib

2. 导入所需的库:

    import pandas as pd
    import matplotlib.pyplot as plt
    import sqlite3

3. 连接到你的数据库(假设是SQLite数据库):

    conn = sqlite3.connect('your_database.db')

4. 使用`pandas`读取数据库中的数据,并将它存储到一个DataFrame对象中:

    query = "SELECT column1, column2 FROM your_table"
    df = pd.read_sql_query(query, conn)

   注意替换`column1`、`column2`和`your_table`为你实际的列名和表名。

5. 利用`pandas`提供的功能和`matplotlib`绘制柱状图:

    df.plot(kind='bar', x='column1', y='column2')
    plt.xlabel('X Label')
    plt.ylabel('Y Label')
    plt.title('Database Data Visualization')
    plt.show()

   在这里,你需要替换`column1`、`column2`为你要展示的列名,并修改`X Label`、`Y Label`、`Database Data Visualization`为你自己喜欢的标签。

6. 关闭数据库连接:

    conn.close()

以上是一个简单的示例代码,你可以根据自己的需求进行修改和优化。希望对你有帮助!如有更多问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 19:37:51

FishC 发表于 2024-5-30 19:32
要使用Python对数据库中的数据进行可视化,你可以使用以下步骤完成代码:

1. 首先,你需要安装所需 ...

数据库用MySQL,数据库名为year,我想要将图标做成动态

FishC 发表于 2024-5-30 19:38:22

豪在这学python 发表于 2024-05-30 19:37
数据库用MySQL,数据库名为year,我想要将图标做成动 ...

如果你想使用MySQL数据库并将图表做成动态的,你可以尝试使用以下步骤完成代码:

1. 首先,确保你已经安装了所需的库。这里我们需要安装`pandas`、`matplotlib`和`mysql-connector-python`库。你可以使用以下命令进行安装:

   pip install pandas matplotlib mysql-connector-python

2. 导入所需的库:

   import pandas as pd
   import matplotlib.pyplot as plt
   import mysql.connector
   import matplotlib.animation as animation

3. 连接到你的MySQL数据库:

   conn = mysql.connector.connect(
       user='your_username',
       password='your_password',
       host='your_host',
       database='year'
   )

   将`your_username`、`your_password`和`your_host`替换为你实际的用户名、密码和主机。

4. 使用`pandas`读取数据库中的数据,并将其存储到一个DataFrame对象中:

   query = "SELECT column1, column2 FROM your_table"
   df = pd.read_sql_query(query, conn)

   将`column1`、`column2`和`your_table`替换为你实际的列名和表名。

5. 创建一个画布和子图:

   fig, ax = plt.subplots()

6. 定义一个更新图表数据的函数:

   def update_data(i):
       # 在此处更新数据
       pass

   你可以在`update_data()`函数中通过查询数据库来更新数据。

7. 使用`matplotlib.animation`库创建动态图表:

   ani = animation.FuncAnimation(fig, update_data, interval=1000)# 每隔1秒更新一次数据
   plt.show()

   这将显示一个动态图表,并每隔1秒调用一次`update_data()`函数。

8. 关闭数据库连接:

   conn.close()

请根据上述步骤修改代码以适应你的实际情况。希望对你有所帮助!如有更多问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 20:02:57

FishC 发表于 2024-5-30 19:38
如果你想使用MySQL数据库并将图表做成动态的,你可以尝试使用以下步骤完成代码:

1. 首先,确保你已 ...

我需要数据库中表头的第一个作为图标的x,第二个表头作为y

FishC 发表于 2024-5-30 20:03:07

豪在这学python 发表于 2024-05-30 20:02
我需要数据库中表头的第一个作为图标的x,第二个表头 ...

如果你想使用MySQL数据库中的表头的第一个列作为x轴,第二个列作为y轴来制作动态图表,你可以按照以下步骤修改代码:

1. 在使用`pandas`读取数据时,设置`header`参数为`0`,以将第一行作为列名:

df = pd.read_sql_query(query, conn, header=0)

2. 修改`update_data()`函数来提取x和y的值,并更新图表数据:

def update_data(i):
    x = df.iloc[:, 0]# 提取第一列作为x轴数据
    y = df.iloc[:, 1]# 提取第二列作为y轴数据

    # 更新图表数据
    ax.clear()# 清空原有图表
    ax.plot(x, y)# 重新绘制图表

# 使用FuncAnimation创建动态图表
ani = animation.FuncAnimation(fig, update_data, interval=1000)

这样,每次调用`update_data()`函数时,它都会从数据框中提取第一列作为x轴数据,第二列作为y轴数据,并重新绘制图表。

希望这对你有帮助!如有更多问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 20:07:01

FishC 发表于 2024-5-30 20:03
如果你想使用MySQL数据库中的表头的第一个列作为x轴,第二个列作为y轴来制作动态图表,你可以按照以下 ...

TypeError: read_sql_query() got an unexpected keyword argument 'header'

FishC 发表于 2024-5-30 20:07:13

豪在这学python 发表于 2024-05-30 20:07
TypeError: read_sql_query() got an unexpected keyw ...

抱歉,我之前给出的代码中使用了一个不存在的`header`参数导致了错误。在`read_sql_query()`函数中,没有`header`这个参数。

要解决这个问题,你可以尝试以下方法:
1. 直接将第一行作为列名,不使用`header`参数:

df = pd.read_sql_query(query, conn)

默认情况下,`pandas`会将第一行作为列名。

2. 如果你的数据表中没有列名,只有数据,请使用`pandas`提供的`names`参数来自定义列名:

df = pd.read_sql_query(query, conn, names=['column1', 'column2'])
将`column1`和`column2`替换为实际的列名。

请根据这些修改尝试进行操作,并避免使用`header`参数。如果还有其他问题,请随时提问!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 20:11:29

FishC 发表于 2024-5-30 20:07
抱歉,我之前给出的代码中使用了一个不存在的`header`参数导致了错误。在`read_sql_query()`函数中,没 ...

好像不对

FishC 发表于 2024-5-30 20:11:45

豪在这学python 发表于 2024-05-30 20:11
好像不对

抱歉给出错误的建议。实际上,`read_sql_query()`函数确实没有`header`参数,它会自动将查询结果的列名作为DataFrame的列名。

在你的情况下,如果你想使用数据库中的第一列作为x轴数据,第二列作为y轴数据,你可以按照以下方式修改代码:

import pandas as pd
import matplotlib.pyplot as plt
import mysql.connector
import matplotlib.animation as animation

# 连接到MySQL数据库
conn = mysql.connector.connect(
    user='your_username',
    password='your_password',
    host='your_host',
    database='year'
)

# 从数据库中读取数据
query = "SELECT * FROM your_table"
df = pd.read_sql_query(query, conn)

# 创建一个画布和子图
fig, ax = plt.subplots()

def update_data(i):
    # 提取x和y的值
    x = df.iloc[:, 0]# 提取第一列作为x轴数据
    y = df.iloc[:, 1]# 提取第二列作为y轴数据

    # 更新图表数据
    ax.clear()# 清空原有图表
    ax.plot(x, y)# 重新绘制图表

# 使用FuncAnimation创建动态图表
ani = animation.FuncAnimation(fig, update_data, interval=1000)

# 显示图表
plt.show()

# 关闭数据库连接
conn.close()

请确保替换`your_username`、`your_password`、`your_host`为正确的用户名、密码和主机。同时,将`your_table`替换为你实际的表名。

现在,`update_data()`函数中的`x`变量提取了DataFrame中的第一列数据,`y`变量提取了第二列数据,并重新绘制图表。

希望这次能够帮到你!如有其他问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 20:13:52

FishC 发表于 2024-5-30 20:11
抱歉给出错误的建议。实际上,`read_sql_query()`函数确实没有`header`参数,它会自动将查询结果的列名 ...

我的表为id name
             1尔豪,现在要x轴显示id的数据,y轴显示name的数据

FishC 发表于 2024-5-30 20:15:15

豪在这学python 发表于 2024-05-30 20:13
我的表为id name
             1尔豪,现在要x轴显 ...

感谢你提供的信息!根据你的描述,如果你想使用数据库表中的`id`列作为x轴数据,`name`列作为y轴数据进行绘图,你可以按照以下方式修改代码:

import pandas as pd
import matplotlib.pyplot as plt
import mysql.connector

# 连接到MySQL数据库
conn = mysql.connector.connect(
    user='your_username',
    password='your_password',
    host='your_host',
    database='year'
)

# 从数据库中读取数据
query = "SELECT id, name FROM your_table"
df = pd.read_sql_query(query, conn)

# 绘制柱状图
plt.bar(df['id'], df['name'])

# 设置x轴和y轴标签
plt.xlabel('id')
plt.ylabel('name')

# 设置图表标题
plt.title('Data Visualization')

# 显示图表
plt.show()

# 关闭数据库连接
conn.close()

在上述代码中,请确保将`your_username`、`your_password`、`your_host`替换为正确的用户名、密码和主机。同时,将`your_table`替换为你实际的表名。

这段代码会从数据库中读取`id`和`name`列的数据,然后使用`plt.bar()`函数绘制柱状图,x轴对应`id`列,y轴对应`name`列。最后设置了x轴和y轴的标签以及标题,并显示图表。

希望这次能够满足你的需求!如有其他问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-30 20:23:10

FishC 发表于 2024-5-30 20:15
感谢你提供的信息!根据你的描述,如果你想使用数据库表中的`id`列作为x轴数据,`name`列作为y轴数据进 ...

C:\Users\Administrator\Pictures\4k\1.png,将这张照片中的各种数据用python以图标的格式写出来

FishC 发表于 2024-5-30 20:23:28

豪在这学python 发表于 2024-05-30 20:23
C:\Users\Administrator\Pictures\4k\1.png,将这张照 ...

如果你想使用Python将一张照片中的各种数据以图表的形式呈现,你需要先将图片转换为RGB像素值的数据。然后,可以使用诸如Matplotlib等库将该数据可视化为不同类型的图表。

以下是一个示例代码,它使用Pillow库(用于对图像进行处理)和Matplotlib库(用于数据可视化)来实现这个目标:

from PIL import Image
import matplotlib.pyplot as plt

# 打开并加载图像
image_path = r'C:\Users\Administrator\Pictures\4k\1.png'
image = Image.open(image_path)

# 将图像转换为RGB模式
image_rgb = image.convert("RGB")

# 获取图像的像素值
pixels = image_rgb.getdata()

# 获取每个像素点的R、G、B值
red_values = []
green_values = []
blue_values = []
for pixel in pixels:
    red, green, blue = pixel
    red_values.append(red)
    green_values.append(green)
    blue_values.append(blue)

# 绘制柱状图
fig, ax = plt.subplots()
ax.bar(range(len(red_values)), red_values, color='red', alpha=0.5, label='Red')
ax.bar(range(len(green_values)), green_values, color='green', alpha=0.5, label='Green')
ax.bar(range(len(blue_values)), blue_values, color='blue', alpha=0.5, label='Blue')

# 设置x轴和y轴标签
ax.set_xlabel('Pixel Index')
ax.set_ylabel('RGB Value')
ax.set_title('Pixel RGB Values')

# 显示图例
ax.legend()

# 显示图表
plt.show()

请确保将 `image_path` 替换为你实际的图像路径。上述代码将打开指定的图像,并将其转换为RGB模式。然后,将每个像素的红、绿、蓝值提取出来,并使用Matplotlib绘制了柱状图,将红色值、绿色值和蓝色值分别显示在不同的柱子上。

希望这可以帮助你实现将图片中的数据以图表的形式展示出来!如有其他问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

豪在这学python 发表于 2024-5-31 08:47:22

FishC 发表于 2024-5-30 20:23
如果你想使用Python将一张照片中的各种数据以图表的形式呈现,你需要先将图片转换为RGB像素值的数据。 ...

import re
import math
import pymysql# 导入数据库
from bs4 import BeautifulSoup
from pyecharts.options import *
from pyecharts.faker import Faker
from pyecharts import options as opts
from pyecharts.globals import ThemeType
from pyecharts.charts import Bar, Pie, Page, Geo, Timeline, Line3D, Scatter, Line


def bar():# 柱状图
    year = Numberselect(Mysqlconnect("select year from countrygdp;"))
    country = Chineseselect(Mysqlconnect("select GDP from countrygdp;"))
    GDP = Numberselect(Mysqlconnect("select rate from countrygdp;"))
    data_dict = {}
    for i in range(len(year)):
      try:
            data_dict].append(, GDP])
      except KeyError:
            data_dict] = []
            data_dict].append(, GDP])
    # 排序年份
    sorted_year_list = sorted(data_dict.keys())# 排序年份
    timeline = Timeline({"theme": ThemeType.LIGHT})# 创建时间线对象
    for year in sorted_year_list:
      data_dict.sort(key=lambda element: element, reverse=True)
      year_data = data_dict[:8]# 取出本年份前八名的国家
      x_data = []
      y_data = []
      for country_gdp in year_data:
            x_data.append(country_gdp)# x轴添加国家
            y_data.append(country_gdp / 100000000)# y轴添加GDP数据,单位为亿元
      bar = Bar()# 构建柱状图
      x_data.reverse()
      y_data.reverse()
      bar.add_xaxis(x_data)
      bar.add_yaxis("GDP亿元", y_data, label_opts=LabelOpts(position="right"), color="#FFFFFF")
      bar.reversal_axis()# 反转x轴,y轴
      bar.set_global_opts(
            title_opts=TitleOpts(title=f"{year}年全球GDP前八数据", title_textstyle_opts=opts.TextStyleOpts(
                color="#FFFFFF")),
            xaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(color='#FFFFFF')),
            yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(color='#FFFFFF')))# 设置每一年的图表标题
      timeline.add(bar, str(year))# 创建时间线对象
    c = timeline.add_schema(# 设置时间为自动播放
      play_interval=1000,# 时间间隔
      is_timeline_show=True,# 是否显示时间
      is_loop_play=True,# 是否循环
      is_auto_play=True# 是否自动播放
    )
    return c


def tab(name, color, size):# 标题
    c = (Pie().set_global_opts(title_opts=opts.TitleOpts(title=name, pos_left='center', pos_top='center',
                                                         title_textstyle_opts=opts.TextStyleOpts(color=color,
                                                                                                 font_size=size))))
    return c


def line():# 折线图
    c = (
      Line()
      .add_xaxis(Faker.choose())
      .add_yaxis(
            'Lab A',
            Faker.values(),
            markline_opts=opts.MarkLineOpts(data=[
                {'yAxis': 150},
                opts.MarkLineItem(type_='min'),
                opts.MarkLineItem(type_='max'),
                opts.MarkLineItem(type_='average'),
            ])).add_yaxis(
            'Lab B',
            Faker.values(),
            markline_opts=opts.MarkLineOpts(data=[
                opts.MarkLineItem(type_='min'),
                opts.MarkLineItem(type_='max'),
                opts.MarkLineItem(type_='average'),
            ])).set_global_opts(
            title_opts=opts.TitleOpts(title='折线图中设置标记', title_textstyle_opts=opts.TextStyleOpts(
                color="#FFFFFF")),
            xaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(color='#FFFFFF')),
            yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(color='#FFFFFF')),
            visualmap_opts=opts.VisualMapOpts(
                pos_top='10',
                pos_right='0',
                is_piecewise=True,
                pieces=[
                  {'gt': 0, 'lte': 50, 'color': '#096'},
                  {'gt': 50, 'lte': 100, 'color': '#ffde33'},
                  {'gt': 100, 'lte': 150, 'color': '#ff9933'},
                  {'gt': 150, 'lte': 200, 'color': '#cc0033'},
                  {'gt': 200, 'lte': 300, 'color': '#660099'},
                  {'gt': 300, 'color': '#7e0023'}
                ],
                out_of_range={'color': '#999'}
            ),
            datazoom_opts=[
                opts.DataZoomOpts(yaxis_index=0),
                opts.DataZoomOpts(type_='inside', yaxis_index=0),
            ]
      )
    )
    return c


def scatter():# 散点图
    # 例1 自定义数据基本示例
    y1 = [, , , , ]
    y2 = [, , , , ]
    c = (
      Scatter()
      .add_xaxis(Faker.choose())
      .add_yaxis('数据1', y1)
      .add_yaxis('数据2', y2)
      .set_global_opts(
            title_opts=opts.TitleOpts(title='散点图', title_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF")),
            xaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(color='#FFFFFF')),
            yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(color='#FFFFFF'))
      )
    )

    return c


def Mysqlconnect(sql):# 数据库连接
    conn = pymysql.connect(
      host='localhost',# 连接名称,一般默认localhost
      user='root',# 数据库用户名,一般都是root
      password='123456',# 数据库密码,用户根据自定义设置
      port=3306,# MySQL端口,系统默认的3306端口
      db='python',# 连接数据库名
      charset='utf8'
    )# 识别的字符编码
    cur = conn.cursor()# 生成游标对象
    cur.execute(sql)
    sql1 = cur.fetchall()# 通过fetchall获得数据
    cur.close()
    conn.close()
    return sql1


def Chineseselect(datas):# 汉字数据筛选
    data = []
    for i in datas[:len(datas)]:
      data.append(re.search("[\u4e00-\u9fff]+", str(i)).group())
    return data


def Numberselect(datas):# 数值数据筛选
    data = []
    for i in datas[:len(datas)]:
      data.append(int(re.search(r"+", str(i)).group()))
    return data


def radius():# 饼图
    cate = Chineseselect(Mysqlconnect("select area from vote_result"))
    data = Numberselect(Mysqlconnect("select vote from vote_result"))
    c = Pie()
    c.add('', , radius=["30%", "70%"], rosetype="radius")
    c.set_global_opts(title_opts=opts.TitleOpts(title="客户销售额占比", padding=,
                                                title_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF")),
                      legend_opts=opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"), type_="scroll",
                                                orient="vertical", pos_right=0, pos_top="middle"))
    c.set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {d}%"))
    c.set_colors(['red', "orange", "yellow", "green", "Cyan", "purple"])

    return c


def geo():# 中国地图
    city_num = [('武汉', 200), ('成都', 70), ('北京', 99),
                ('西安', 80), ('杭州', 60), ('贵阳', 34),
                ('上海', 65), ('深圳', 54), ('乌鲁木齐', 76),
                ('哈尔滨', 47), ('兰州', 56), ('信阳', 85)]
    start_end = [('宁波', '成都'), ('武汉', '北京'), ('武汉', '西安'),
               ('长沙', '杭州'), ('武汉', '贵阳'), ('武汉', '上海'),
               ('甘肃', '深圳'), ('北京', '乌鲁木齐'), ('上海', '哈尔滨'),
               ('武汉', '兰州'), ('西藏', '信阳')]
    c = Geo()
    c.add_schema(maptype='china', itemstyle_opts=opts.ItemStyleOpts(color='#323c48', border_color='white'))
    c.add('', data_pair=city_num, color='white')# 4.添加数据
    c.add('', data_pair=start_end, type_="lines", label_opts=opts.LabelOpts(is_show=False),
          effect_opts=opts.EffectOpts(symbol="arrow", color='gold', symbol_size=7))
    c.set_global_opts(title_opts=opts.TitleOpts(title=""))

    return c


def scatter3D():# 弹簧图
    data = []
    for t in range(0, 25000):
      _t = t / 1000
      x = (1 + 0.25 * math.cos(75 * _t)) * math.cos(_t)
      y = (1 + 0.25 * math.cos(75 * _t)) * math.sin(_t)
      z = _t + 2.0 * math.sin(75 * _t)
      data.append()
    c = (
      Line3D()
      .add("", data,
             xaxis3d_opts=opts.Axis3DOpts(Faker.clock, type_='value', axislabel_opts=opts.LabelOpts(color="white")),
             # 设置坐标轴白色
             yaxis3d_opts=opts.Axis3DOpts(Faker.week_en, type_="value", axislabel_opts=opts.LabelOpts(color="white")),
             grid3d_opts=opts.Grid3DOpts(
               width=100, depth=100, rotate_speed=150, is_rotate=True, axislabel_opts=opts.LabelOpts(color="white")
             )
             )
      .set_global_opts(
            visualmap_opts=opts.VisualMapOpts(max_=30, min_=0, range_color=Faker.visual_color),
            title_opts=opts.TitleOpts(title="弹簧3D折线图", title_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF")),
      )
    )
    return c


def Summary():# 汇总图
    page = Page()
    page.add(
      tab("班级:\t22数据本\n学号:\t2022402223\n姓名:\t郑尔豪", "#2CB34A", 20),
      bar(),
      tab("数据可视化大屏", "#2CB34A", 30),
      scatter3D(),
      radius(),
      line(),
      geo(),
      scatter()
    )
    return page


def Zhizuo():# 修改布局
    with open("2021402156Mrtian.html", "r+", encoding='utf-8') as html:
      html_bf = BeautifulSoup(html, 'lxml')
      divs = html_bf.select('.chart-container')
      divs["style"] = "width:10%;height:10%;position:absolute;top:0;left:2%;"
      divs["style"] = "width:40%;height:40%;position:absolute;top:12%;left:0;"
      divs["style"] = "width:35%;height:10%;position:absolute;top:2%;left:30%;"
      divs["style"] = "width:30%;height:40%;position:absolute;top:10%;left:36%;"
      divs["style"] = "width:40%;height:35%;position:absolute;top:12%;left:55%;"
      divs["style"] = "width:30%;height:35%;position:absolute;top:55%;left:2%;"
      divs["style"] = "width:60%;height:50%;position:absolute;top:45%;left:15%;"
      divs["style"] = "width:35%;height:40%;position:absolute;top:55%;left:60%;"
      body = html_bf.find("body")
      body[
            "style"] = "background-image: url(https://tse1-mm.cn.bing.net/th/id/OIP-C.BLVs3j-wt2XVI2NdeI9FPAHaDt?w=342&h" \
                     "=175&c=7&r=0&o=5&pid=1.7);background-size:cover"# 背景颜色
      html_new = str(html_bf)
      html.seek(0, 0)
      html.truncate()
      html.write(html_new)


if __name__ == '__main__':# 主函数
    Summary().render('xxx.html')
    Zhizuo()
根据这些代码,完成一个讲解、解析ppt内容
页: [1] 2
查看完整版本: 实现数据可视化