欢迎来到本篇技术博客!今天我们将和大家一起探索搭建数据大屏的全过程。作为腾讯云 Cloud Studio 实战训练营的参与者,我们将从零开始构建一个令人惊叹的数据大屏的项目。
在这个项目中,我们主要使用了两项关键技术:nuxtjs 和 datav。
- Nuxt.js 是一个基于 Vue.js 的轻量级应用框架,它提供了丰富的功能和优秀的开发体验,使我们能够快速构建出具有高度可扩展性的数据大屏应用。
- datav 是一款强大的数据可视化工具,它为我们呈现了绚丽多彩、直观易懂的数据展示效果。
同时为了更加友好的展示该项目,我们还用到了 Python这门开发语言 。通过编写 Python 脚本, 从 CSDN上抓取博客数据。这些数据将成为我们数据大屏的基础,为我们展示数据的价值和意义提供支持。
在本篇博客中,我们将详细介绍 Cloud Studio 如和使用以及搭建数据大屏的步骤和流程。无论您是初学者还是有一定经验的开发者,我们相信本文都将为您提供有用的指导和启示。让我们一起开始这个令人兴奋的技术之旅吧!
通过阅读本篇博客你将学到如下内容
Cloud Studio
进行项目开发Cloud Studio
是一个什么 如和使用Cloud Studio
项目链接到 coding
作为项目的管理仓库Python
来爬取CSDN
博客信息python
的基本使用Nuxt.js
的安装和基本配置DataV
的使用UI/UX 设计
页面布局、交互设计、视觉设计等方面。首先我们先登录Cloud Studio 这个网站 Cloud Studio , 点击右上角的 登录注册 按钮
Cloud Studio 贴心的准备了三种登录方式(Coding DevOps、微信、Github), 这里我们选择的是微信登录, 各位开发者可以根据自己的喜好选择登录方式哦!!
登录之后进入主界面,里面集成了很多模板,可以选择自己需要使用的模板直接初始化项目。
模板主要分为:常用模板 , 框架模板, 建站模板 , 云原生模板。常见的有Java、Python、Go、Nodejs、Net、主流的前端框架都可以快速创建使用。真的好齐全哦!!!
如果模板里没有你想要的还可以自己新建一个模板哦! 这个功能我们不做详细讲解, 感兴趣的同学可以 去体验一下哦 !
我们本次是使用Nuxt + datav 搭建一个数据大屏的项目, 这里我们直接新建工作空间,进行项目搭建
当我们点击新建工作空间 里面的配置中有 在弹出的创建工作空间窗口中,需要进行以下配置:
点击 选择仓库服务商 这里我选的是coding 根据喜好来就行哦!
选择coding之后需要关联一下团队, 输入coding的团队域名前缀就好了
关联好团队之后点击继续, 跳转到绑定页面, 直接点击确定授权即可
在coding中选择按需选择 点击选择
填写项目信息完成创建即可
在创建的项目中选择代码仓库 创建代码仓库即可
在仓库中选择在coding中创建的git 仓库即可, 因为要用到python 所以这里选择的开发环境是All in One
点击创建, 来创建项目
注意 项目加载需要一定时间哦!!
当项目空间加载完成之后, 展现在我们面前的就是 工程环境喽!! 是不是和vscode 很像啊!!
如图 我们在工程目录中,创建两个项目文件pythonObject
和 webObject
搭建项目的步骤如下:
cd webProject
, 进入项目 webProject
nvm
版本管理工具, 安装19.0.0
的node 环境, 指令 nvm install 19.0.0
npx create-nuxt-app webDatav
, 创建 webDatav
项目脚手架插件选择
为了更好的开发, 我们可以安装一些插件, 如图所示
设置适合自己的字体大小
步骤如下
如果直接运行项目, 会发现,项目无法正常打开,如图
这里我们就需要进行config
的配置了,在nuxt.config.js
中添加如下代码,再次运行
server: {
port: 3000, // default: 3000
host: '0.0.0.0' // default: localhost
}
修改后运行如图
npm install @jiaminghi/data-view
下载datav
的插件plugins
文件中创建datav.js
文件中添加代码import Vue from 'vue'
// 将自动注册所有组件为全局组件
import dataV from '@jiaminghi/data-view'
Vue.use(dataV)
nuxt.config.js
中配置在plugins
中添加 { src: '@/plugins/datav.js', ssr: false }
, bulid
中添加 '/^@jiaminghi/'
plugins: [
{ src: '@/plugins/datav.js', ssr: false }
],
build: {
transpile: [/^element-ui/, '/^@jiaminghi/'],
},
sass
用于样式编写npm install [email protected] [email protected] -D
安装sass
from selenium import webdriver
import json
from selenium.webdriver.common.by import By
from selenium.common.exceptions import NoSuchElementException
import time
# 设置ChromeDriver的路径
driver_path = ''
# 创建Chrome WebDriver对象
driver = webdriver.Chrome(driver_path)
# 打开网页
url = 'https://so.csdn.net/so/search?spm=1001.2100.3001.7499&q=%E8%85%BE%E8%AE%AF%E4%BA%91%20Cloud%20Studio%20%E5%AE%9E%E6%88%98%E8%AE%AD%E7%BB%83%E8%90%A5&t=blog&u=&utm_medium=distribute.pc_search_hot_word.none-task-hot_word-alirecmd-1-%E8%85%BE%E8%AE%AF%E4%BA%91%20Cloud%20Studio%20%E5%AE%9E%E6%88%98%E8%AE%AD%E7%BB%83%E8%90%A5-null-null.172%5Ev8%5Etag_flag&depth_1-utm_source=distribute.pc_search_hot_word.none-task-hot_word-alirecmd-1-%E8%85%BE%E8%AE%AF%E4%BA%91%20Cloud%20Studio%20%E5%AE%9E%E6%88%98%E8%AE%AD%E7%BB%83%E8%90%A5-null-null.172%5Ev8%5Etag_flag'
driver.get(url)
time.sleep(5)
# 找到结果元素
results = driver.find_element(By.CLASS_NAME, "so-result-list").find_elements(By.CLASS_NAME, "list-item")
# 创建一个空列表用于存储数据
data = []
# 遍历结果元素并提取数据
for result in results:
time.sleep(5)
title = result.find_element(By.CLASS_NAME, "title").find_element(By.TAG_NAME, 'a').text
if "实战训练营】" in title:
description = result.find_element(By.CLASS_NAME, "item-bd__cont").find_element(By.CLASS_NAME, "row2").text
try:
read = result.find_element(By.CLASS_NAME, "item-bd__cont").find_element(By.CLASS_NAME,"item-ft").find_element(By.CLASS_NAME, "btm-view").find_element(By.CLASS_NAME, "num").text
except NoSuchElementException:
read = 0
try:
zan = result.find_element(By.CLASS_NAME, "item-bd__cont").find_element(By.CLASS_NAME,
"item-ft").find_element(
By.CLASS_NAME, "btm-dig").find_element(By.CLASS_NAME, "num").text
except NoSuchElementException:
zan = 0
try:
comment = result.find_element(By.CLASS_NAME, "item-bd__cont").find_element(By.CLASS_NAME,
"item-ft").find_element(
By.CLASS_NAME, "btm-comment").find_element(By.CLASS_NAME, "num").text
except NoSuchElementException:
comment = 0
# read = result.find_element(By.CLASS_NAME, "item-bd__cont").find_element(By.CLASS_NAME, "item-ft").find_element(By.CLASS_NAME, "btm-view").find_element(By.CLASS_NAME, "num").text
# zan = result.find_element(By.CLASS_NAME, "item-bd__cont").find_element(By.CLASS_NAME, "item-ft").find_element(By.CLASS_NAME, "btm-dig").find_element(By.CLASS_NAME, "num").text
# comment = result.find_element(By.CLASS_NAME,"item-bd__cont").find_element(By.CLASS_NAME, "item-ft").find_element(By.CLASS_NAME, "btm-comment").find_element(By.CLASS_NAME, "num").text
idx = result.get_attribute('i')
# 将提取的数据存储为字典格式
item = {
'title': title, # 标题
'description': description, # 描述
'read': read, # 阅读数量
'zan': zan, # 点赞数量
'comment': comment # 评论数量
}
print(idx)
# 将字典添加到数据列表中
data.append(item)
else:
print(f'不是目标文章, 当前文章标题是:{title}')
# 保存数据为JSON文件
with open('data.json', 'w', encoding='utf-8') as f:
json.dump(data, f, ensure_ascii=False, indent=4)
# 关闭WebDriver
driver.quit()
py 脚本是使用selenium
进行数据获取的, 但是脚本在Cloud Studio
中运行时,提示的是Chrome
版本不匹配, 这里找了好久也没有找到解决办法, 没办法在本地的pycharm
中运行后获取的数据
报错截图
8月1日
选择提交项目的目录
执行命令
git init
git add .
git commit -m
‘备注’git remote add origin [email protected]:shiqingqing/test.git
git pull origin master
git push -u origin master
这里可能会报错 所以建议不用这句 直接使用git push -u origin master -f
强制上传前端数据大屏地址
python脚本地址
Cloud Studio 地址
Cloud Studio 总体上说还是很优秀的, 解决了本地开发环境配置的烦恼, 其次Cloud Studio
还提供了许多模板 例如:常用模板 , 框架模板, 建站模板 , 云原生模板 可以说是开箱即用, 极大的方便了开发者, 但与此同时我在使用Cloud Studio
进行数据大屏开发的时候, 也遇见了一些小问题, 希望官方可以及时解决呦!!
Cloud Studio
偶现问题, 在运行代码的时候,会出现闪退现象.
在执行py 脚本时, 由于我使用的是 selenium
, 对浏览器版本有要求, 我无法判断从哪里更新内置的 Chrome
版本 , 会出现如下的问题
git 提交时, 如果默认选择 zsh
尽心git push
无法提交, 但是 切换 bash
时就可以提交成功了.
对于上述三个小问题并不影响Cloud Studio
的优秀, 希望Cloud Studio
越来越强大, 给予开发者更多的便利.