TimescaleDB实战:5分钟搞定物联网传感器数据存储与查询(附Python示例)

# TimescaleDB实战:5分钟搞定物联网传感器数据存储与查询(附Python示例) 如果你正在处理物联网传感器数据,比如温度、湿度、压力这些随时间不断产生的信息流,那么你很可能已经感受到了传统数据库的力不从心。每秒成千上万条数据涌入,既要存得快,又要查得准,还得能轻松地按时间聚合分析——这可不是MySQL或者普通PostgreSQL的强项。我最初在做一个工业设备监控项目时,就遇到了这个瓶颈:数据量稍微一大,查询就慢得让人抓狂,存储空间更是飞速膨胀。 后来我发现了TimescaleDB,一个基于PostgreSQL的时序数据库扩展。它最吸引我的地方在于,你不需要放弃熟悉的SQL语法,就能获得专门为时间序列数据优化的性能。简单来说,它让PostgreSQL“学会”了如何处理海量的时序数据。今天,我就以一个实际的传感器数据采集场景为例,带你快速上手TimescaleDB,从环境搭建、数据表设计,到批量写入和复杂查询,全程用Python代码演示。目标是让你在5分钟内,看到一个可运行的完整示例。 ## 1. 环境准备与TimescaleDB快速部署 在开始写代码之前,我们得先把数据库环境准备好。TimescaleDB有多种部署方式,对于本地开发和测试,我强烈推荐使用Docker,这能避免很多依赖和配置上的麻烦。 ### 1.1 使用Docker启动TimescaleDB 如果你已经安装了Docker,那么启动一个TimescaleDB实例只需要一条命令。这里我们使用最新的、基于PostgreSQL 16的镜像。 ```bash # 拉取TimescaleDB官方镜像 docker pull timescale/timescaledb:latest-pg16 # 运行容器,将PostgreSQL默认端口5432映射到本地的5432端口 docker run -d \ --name my-timescaledb \ -p 5432:5432 \ -e POSTGRES_PASSWORD=your_secure_password \ -e POSTGRES_DB=sensor_db \ timescale/timescaledb:latest-pg16 ``` 命令参数解释: * `-d`: 后台运行容器。 * `--name my-timescaledb`: 给容器起个名字,方便管理。 * `-p 5432:5432`: 端口映射,将容器内的5432端口暴露给主机。 * `-e POSTGRES_PASSWORD`: 设置PostgreSQL的超级用户密码,**请务必替换`your_secure_password`为一个强密码**。 * `-e POSTGRES_DB`: 指定容器启动时创建的默认数据库名,这里我们叫`sensor_db`。 执行后,一个完整的TimescaleDB服务就在本地运行起来了。你可以用任何PostgreSQL客户端(如`psql`、pgAdmin、DBeaver)连接它,主机是`localhost`,端口`5432`,用户名`postgres`,密码是你刚才设置的。 ### 1.2 安装Python依赖 我们的示例将使用Python来连接和操作数据库。你需要安装两个核心库:`psycopg2`(或它的优化版`psycopg2-binary`)用于连接PostgreSQL,以及`pandas`方便我们生成和操作模拟数据。 ```bash # 使用pip安装 pip install psycopg2-binary pandas ``` > 注意:在生产环境中,通常建议从源码编译`psycopg2`以获得最佳性能和兼容性,但对于快速上手和测试,`psycopg2-binary`预编译包更方便。 ### 1.3 在数据库中启用TimescaleDB扩展 连接到数据库后,第一件事就是在目标数据库中启用TimescaleDB扩展。这只需要执行一条SQL命令。你可以通过命令行工具`psql`连接,或者直接在接下来的Python脚本里执行。 ```sql -- 连接到 sensor_db 数据库后执行 CREATE EXTENSION IF NOT EXISTS timescaledb; ``` 这条命令会加载TimescaleDB的所有功能和优化。现在,你的PostgreSQL就已经“升级”为时序数据库了。 ## 2. 设计传感器数据表并转换为超表(Hypertable) TimescaleDB的核心魔法在于**超表(Hypertable)**。对外,它看起来就是一张普通的PostgreSQL表;对内,它自动按时间(和其他维度)将数据分割成一个个“块”(Chunk)来管理。这带来了巨大的好处:写入时数据被高效路由到对应的块,查询时数据库可以快速定位到相关时间段的块,避免扫描全表。 ### 2.1 设计数据表结构 假设我们监控的是工厂车间的环境传感器,每个传感器每秒上报一次数据。我们先创建一个符合直觉的普通表。 ```sql -- 创建传感器数据表 CREATE TABLE sensor_telemetry ( -- 时间戳,时序数据的核心,必须非空 time TIMESTAMPTZ NOT NULL, -- 传感器唯一标识 sensor_id VARCHAR(50) NOT NULL, -- 测量值:温度 temperature DOUBLE PRECISION, -- 测量值:湿度 humidity DOUBLE PRECISION, -- 测量值:大气压 pressure DOUBLE PRECISION, -- 我们可以添加一个复合主键,注意必须包含时间列 PRIMARY KEY (sensor_id, time) ); ``` 这个表结构很直观。`TIMESTAMPTZ`是带时区的时间戳类型,比`TIMESTAMP`更能避免时区混乱。`DOUBLE PRECISION`对应Python的`float`,适合存储带小数的测量值。 ### 2.2 将普通表转换为超表 创建普通表后,使用TimescaleDB提供的函数`create_hypertable()`将其转换为超表。这是最关键的一步。 ```sql -- 将 sensor_telemetry 表转换为按 time 列分区的超表 SELECT create_hypertable('sensor_telemetry', 'time'); ``` 这个函数调用告诉TimescaleDB:“请把`sensor_telemetry`表按照`time`字段自动进行时间分区”。之后,所有针对此表的插入和查询,都会由TimescaleDB的引擎进行优化处理。 你还可以指定分区时间间隔(`chunk_time_interval`),默认是7天。意思是每7天的数据会存储在一个物理“块”里。如果你的数据非常密集(比如每秒一条),可以考虑缩小这个间隔(例如1天),让每个块的大小更合理,查询效率更高。 ```sql -- 创建超表时指定按天分区 SELECT create_hypertable('sensor_telemetry', 'time', chunk_time_interval => INTERVAL '1 day'); ``` ## 3. 使用Python实现高效批量数据写入 时序数据的典型特点是高频写入。如果逐条执行`INSERT`语句,会产生巨大的网络和事务开销。TimescaleDB和PostgreSQL一样,对批量写入有极好的支持。下面我们用Python模拟生成一段时间内的传感器数据,并一次性插入数据库。 ### 3.1 建立数据库连接 首先,我们编写一个通用的连接函数。 ```python import psycopg2 from psycopg2.extras import execute_batch import pandas as pd from datetime import datetime, timedelta import random def get_db_connection(): """建立并返回一个TimescaleDB数据库连接""" conn = psycopg2.connect( host="localhost", port="5432", database="sensor_db", user="postgres", password="your_secure_password" # 替换为你的密码 ) return conn ``` ### 3.2 生成模拟传感器数据并批量插入 我们模拟10个传感器,在过去24小时内,每分钟产生一条数据。 ```python def generate_and_insert_sensor_data(): """生成模拟数据并批量插入超表""" conn = get_db_connection() cursor = conn.cursor() sensor_ids = [f'sensor_{i:03d}' for i in range(1, 11)] # sensor_001 到 sensor_010 end_time = datetime.utcnow() start_time = end_time - timedelta(hours=24) # 生成时间序列,每分钟一个点 time_points = pd.date_range(start=start_time, end=end_time, freq='1min') data_to_insert = [] for t in time_points: for sensor_id in sensor_ids: # 生成合理的随机测量值 record = ( t, sensor_id, round(random.uniform(18.0, 32.0), 2), # 温度 18-32°C round(random.uniform(30.0, 70.0), 2), # 湿度 30-70% round(random.uniform(980.0, 1020.0), 2) # 气压 980-1020 hPa ) data_to_insert.append(record) print(f"共生成 {len(data_to_insert)} 条模拟数据记录。") # 使用 execute_batch 进行高效批量插入 insert_query = """ INSERT INTO sensor_telemetry (time, sensor_id, temperature, humidity, pressure) VALUES (%s, %s, %s, %s, %s) """ try: execute_batch(cursor, insert_query, data_to_insert) conn.commit() print("数据批量插入成功!") except Exception as e: conn.rollback() print(f"插入数据时发生错误: {e}") finally: cursor.close() conn.close() if __name__ == "__main__": generate_and_insert_sensor_data() ``` 这段代码的关键点: 1. **使用`pandas.date_range`**:高效生成规则的时间序列。 2. **准备数据列表**:将所有要插入的记录先缓存在一个Python列表里。 3. **使用`execute_batch`**:这是`psycopg2.extras`提供的一个辅助函数,它比简单的`cursor.executemany()`更智能,会将大批量操作分组提交,在性能和内存使用上取得平衡,是写入时序数据的最佳实践。 运行这个脚本,大约14400条(10传感器 * 24小时 * 60分钟)数据会在几秒钟内写入数据库。你可以感受一下这种批量写入的速度。 ## 4. 执行时间序列聚合与分析查询 数据存进去,最终是为了查出来分析。TimescaleDB完全兼容SQL,所以你可以使用所有熟悉的查询语句。更重要的是,它提供了一系列强大的时间序列专用函数。 ### 4.1 基础时间范围查询 查询某个传感器最近一小时的所有原始数据。 ```python def query_recent_data(sensor_id='sensor_005', hours=1): """查询指定传感器最近N小时的原始数据""" conn = get_db_connection() cursor = conn.cursor() query = """ SELECT time, sensor_id, temperature, humidity, pressure FROM sensor_telemetry WHERE sensor_id = %s AND time > NOW() - INTERVAL '%s hours' ORDER BY time DESC; """ cursor.execute(query, (sensor_id, hours)) results = cursor.fetchall() print(f"\n传感器 {sensor_id} 最近{hours}小时的数据(最新{len(results)}条):") for row in results[:5]: # 只打印前5条 print(row) if len(results) > 5: print("...") cursor.close() conn.close() return results ``` ### 4.2 使用`time_bucket`进行时间聚合 这是TimescaleDB里我最喜欢的功能之一。`time_bucket`函数可以将时间线划分为固定的“桶”(比如5分钟、1小时),然后对每个桶内的数据进行聚合计算(求平均、最大、最小等)。这相当于在SQL层面轻松实现了数据降采样。 ```python def query_hourly_avg_temperature(sensor_id='sensor_005', lookback_days=1): """查询指定传感器过去N天内每小时的温度平均值""" conn = get_db_connection() cursor = conn.cursor() query = """ SELECT time_bucket('1 hour', time) AS one_hour, -- 按1小时分桶 AVG(temperature) as avg_temp, MIN(temperature) as min_temp, MAX(temperature) as max_temp, COUNT(*) as readings FROM sensor_telemetry WHERE sensor_id = %s AND time > NOW() - INTERVAL '%s days' GROUP BY one_hour ORDER BY one_hour DESC; """ cursor.execute(query, (sensor_id, lookback_days)) results = cursor.fetchall() print(f"\n传感器 {sensor_id} 过去{lookback_days}天每小时温度统计:") for bucket, avg_t, min_t, max_t, cnt in results: print(f" 时间窗: {bucket:%Y-%m-%d %H:%M}, 平均温度: {avg_t:.2f}°C, 范围: [{min_t:.2f}, {max_t:.2f}], 读数: {cnt}") cursor.close() conn.close() ``` 运行这个函数,你会得到类似下面的输出,非常清晰地展示了温度在每个小时内的波动情况。 ``` 传感器 sensor_005 过去1天每小时温度统计: 时间窗: 2023-10-27 15:00, 平均温度: 24.56°C, 范围: [23.10, 26.20], 读数: 60 时间窗: 2023-10-27 14:00, 平均温度: 24.12°C, 范围: [22.80, 25.50], 读数: 60 ... ``` ### 4.3 多传感器聚合对比 我们还可以一次性查询所有传感器在过去3小时内的平均温度,并进行排序,快速找出温度最高或最低的区域。 ```python def compare_sensors_last_3_hours(): """对比所有传感器在过去3小时内的平均温度和最新读数""" conn = get_db_connection() cursor = conn.cursor() # 使用 last 聚合函数获取每个传感器的最新读数 query = """ SELECT sensor_id, AVG(temperature) as avg_temp_last_3h, AVG(humidity) as avg_hum_last_3h, LAST(temperature, time) as latest_temp, -- 获取时间戳最大的那条数据的温度值 LAST(time, time) as latest_time FROM sensor_telemetry WHERE time > NOW() - INTERVAL '3 hours' GROUP BY sensor_id ORDER BY avg_temp_last_3h DESC; """ cursor.execute(query) results = cursor.fetchall() print(f"\n过去3小时所有传感器状态对比 (按平均温度降序):") print(f"{'传感器ID':<12} {'平均温度(°C)':<15} {'平均湿度(%)':<15} {'最新温度':<12} {'最新时间'}") print("-" * 70) for sid, avg_t, avg_h, latest_t, latest_ts in results: print(f"{sid:<12} {avg_t:<15.2f} {avg_h:<15.2f} {latest_t:<12.2f} {latest_ts:%H:%M:%S}") cursor.close() conn.close() ``` 这个查询展示了TimescaleDB另一个强大功能:**窗口函数和特定聚合函数**(如`LAST`)。`LAST(temperature, time)`能方便地获取每个分组内,按`time`排序后的最后一条记录的`temperature`值,对于查看传感器最新状态非常有用。 ## 5. 高级特性实战:连续聚合与数据管理 当数据量变得非常庞大时,即使有`time_bucket`,实时计算长时间范围的聚合(比如“过去一年的月平均温度”)仍然很慢。这时就需要**连续聚合(Continuous Aggregates)**。 ### 5.1 创建连续聚合物化视图 连续聚合就像一个自动刷新的物化视图。你定义好聚合规则(例如,按小时聚合),TimescaleDB会在后台自动计算并存储结果。之后查询这个视图,速度会飞快。 ```python def create_continuous_aggregate(): """创建一个按小时聚合的连续聚合视图""" conn = get_db_connection() cursor = conn.cursor() create_view_sql = """ CREATE MATERIALIZED VIEW sensor_telemetry_hourly WITH (timescaledb.continuous) AS -- 关键:声明为连续聚合 SELECT sensor_id, time_bucket('1 hour', time) AS bucket, AVG(temperature) AS avg_temp, AVG(humidity) AS avg_hum, AVG(pressure) AS avg_press, MAX(temperature) AS max_temp, MIN(temperature) AS min_temp FROM sensor_telemetry GROUP BY sensor_id, bucket; """ try: cursor.execute(create_view_sql) conn.commit() print("连续聚合视图 'sensor_telemetry_hourly' 创建成功!") except Exception as e: conn.rollback() # 如果视图已存在,可能会报错,这里简单处理 print(f"创建视图时可能已存在,或其他错误: {e}") # 为这个物化视图添加索引以优化查询 try: cursor.execute("CREATE INDEX ON sensor_telemetry_hourly (sensor_id, bucket DESC);") conn.commit() print("已为聚合视图添加索引。") except Exception as e: conn.rollback() print(f"创建索引时出错: {e}") cursor.close() conn.close() ``` 创建完成后,你可以像查询普通表一样查询这个视图,但速度是天壤之别。 ```python def query_from_continuous_aggregate(sensor_id='sensor_001', days=7): """从连续聚合视图中快速查询多日数据""" conn = get_db_connection() cursor = conn.cursor() query = """ SELECT bucket, avg_temp, max_temp, min_temp FROM sensor_telemetry_hourly WHERE sensor_id = %s AND bucket > NOW() - INTERVAL '%s days' ORDER BY bucket DESC; """ cursor.execute(query, (sensor_id, days)) results = cursor.fetchall() print(f"\n从连续聚合视图查询传感器 {sensor_id} 过去{days}天每小时数据 (极快):") for bucket, avg, max_v, min_v in results[:10]: print(f" 小时: {bucket:%m-%d %H:00}, 平均: {avg:.2f}, 最高: {max_v:.2f}, 最低: {min_v:.2f}") cursor.close() conn.close() ``` ### 5.2 设置数据保留策略 传感器数据通常具有时效性,我们可能只关心最近30天或90天的详细数据。TimescaleDB可以自动清理旧数据。 ```python def add_retention_policy(): """为原始数据表添加保留策略,自动删除30天前的数据""" conn = get_db_connection() cursor = conn.cursor() # 首先,确保 timescaledb_toolkit 扩展已安装(某些高级函数需要) cursor.execute("CREATE EXTENSION IF NOT EXISTS timescaledb_toolkit;") # 添加保留策略 add_policy_sql = """ SELECT add_retention_policy('sensor_telemetry', INTERVAL '30 days'); """ try: cursor.execute(add_policy_sql) conn.commit() print("数据保留策略已添加:将自动删除超过30天的数据。") except Exception as e: conn.rollback() # 如果策略已存在,会报错 print(f"添加保留策略时出错 (可能已存在): {e}") cursor.close() conn.close() ``` 这个策略会以后台任务的形式运行,定期检查并删除过期数据块,帮你省去手动清理的麻烦,也避免了存储空间的无限增长。 ## 6. 与可视化工具集成(以Grafana为例) 存储和查询的最终目的是为了洞察。将TimescaleDB与Grafana这样的可视化工具连接起来,可以轻松搭建实时监控仪表盘。 1. **在Grafana中添加数据源**:选择“PostgreSQL”类型。 2. **配置连接**: * Host: `localhost:5432` * Database: `sensor_db` * User/Password: 你的数据库凭证 * SSL Mode: `disable` (对于本地测试) 3. **创建仪表盘**:使用Grafana强大的查询编辑器,直接编写SQL查询你的超表和连续聚合视图。 例如,在Grafana面板的SQL编辑器中,你可以输入: ```sql -- 绘制过去24小时,传感器001的温度曲线 SELECT time AS "time", temperature as "温度" FROM sensor_telemetry WHERE sensor_id = 'sensor_001' AND $__timeFilter(time) ORDER BY time ``` Grafana的`$__timeFilter`宏会自动替换为当前仪表盘选中的时间范围。你还可以创建更复杂的面板,比如同时显示多个传感器的温度对比、显示每小时聚合值的柱状图等。由于TimescaleDB查询高效,这些图表都能做到近乎实时的刷新。 走到这一步,你已经拥有了一个从数据采集、高效存储、灵活分析到可视化展示的完整物联网传感器数据处理流水线。TimescaleDB在其中扮演了坚实可靠的数据基石角色,它用标准的SQL接口,让你无需学习新技术栈,就能驾驭海量的时间序列数据。

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

Python内容推荐

2026年电工杯B题:嵌入式社区养老服务站的建设与优化问题【思路、Python代码、Matlab代码、论文(持续更新中......)】

2026年电工杯B题:嵌入式社区养老服务站的建设与优化问题【思路、Python代码、Matlab代码、论文(持续更新中......)】

内容概要:本文围绕“2026年电工杯B题:嵌入式社区养老服务站的建设与优化问题”提供系统化的解题资源,涵盖问题分析思路、Python与Matlab代码实现及竞赛论文撰写指导,内容持续更新完善。资源不仅聚焦B题的养老站点选址、资源配置与运营优化建模,还同步整合了A题“绿电直连型电氢氨园区优化运行”的相关解决方案。同时,文档拓展覆盖多个科研与工程应用方向,包括状态估计(如UKF、EKF、AUKF)、多通道滤波、轴承故障诊断、机器学习与深度学习(CNN、LSTM、SVM等)、路径规划、信号处理、电力系统优化、无人机控制、通信协议优化等领域,配套大量可运行的算法代码与Simulink仿真模型,适用于数学建模备赛、科研项目开发与学术论文复现。; 适合人群:参加数学建模竞赛(如电工杯、数模国赛等)的本科生、研究生,以及从事智能优化、信号处理、电力系统、机器学习、自动化控制等相关领域的科研人员与技术开发者。; 使用场景及目标:①辅助完成电工杯B题中社区养老服务站的选址决策、资源调度与系统优化建模;②提供主流智能算法(如粒子群优化、卡尔曼滤波、LSTM预测、CNN故障诊断等)的代码实现与应用案例参考;③支持科研项目的快速原型构建、算法验证与学术成果复现,提升建模效率与技术创新能力。; 阅读建议:建议结合公众号“荔枝科研社”提供的网盘资源同步学习,优先按照目录结构梳理问题逻辑与技术路线,针对具体模块进行代码调试与理论推导,注重算法在实际工程问题中的迁移应用与优化能力培养。

Using Redis As a Time Series Database: Why and How

Using Redis As a Time Series Database: Why and How

Using Redis As a Time Series Database: Why and How

Spark window functions

Spark window functions

源码下载地址: https://pan.quark.cn/s/5252208f3fb6 MySQL-OLAP 窗口函数

城市轨道交通供电系统研究(Matlab代码实现)

城市轨道交通供电系统研究(Matlab代码实现)

内容概要:本文围绕《城市轨道交通供电系统研究(Matlab代码实现)》这一科研资源,系统阐述了城市轨道交通供电系统的建模、仿真与优化控制方法,重点聚焦于基于Matlab的状态估计技术与系统仿真。核心内容涵盖多种先进状态估计算法,如无迹卡尔曼滤波(UKF)、自适应无迹卡尔曼滤波(AUKF)、扩展无迹卡尔曼滤波(EUKF)等在电力系统三相状态估计中的应用,特别针对负荷突变场景下的动态响应与估计精度问题进行了深入研究。同时,文档整合了微电网、储能配置、配电网重构等典型应用场景,构建了一个面向轨道交通供电系统多维度问题的综合性技术体系,提供了从理论建模到代码实现的完整解决方案。; 适合人群:具备一定电力系统基础知识和Matlab编程能力,从事轨道交通、电力系统自动化、智能电网等领域研究的研究生、科研人员及工程技术人员,尤其适合工作1-3年、希望提升系统建模与仿真能力的研发人员。; 使用场景及目标:①掌握城市轨道交通供电系统的建模与动态仿真方法;②深入理解并应用UKF系列状态估计算法解决实际电力系统问题;③开展含新能源接入与负荷波动的供电系统优化研究;④支撑学术论文复现、课程设计或科研项目开发; 阅读建议:此资源以Matlab代码为核心载体,强调理论与实践深度融合,建议读者结合文档内容逐模块运行与调试代码,深入剖析各算法在不同工况下的性能表现,并通过提供的网盘链接获取完整代码与资料进行系统化学习与拓展研究。

网络安全基于xss-labs靶场的XSS代码审计技术在芯片行业Web应用中的防御实践与合规落地

网络安全基于xss-labs靶场的XSS代码审计技术在芯片行业Web应用中的防御实践与合规落地

内容概要:本文以xss-labs靶场20关实战为基础,系统讲解反射型、存储型与DOM型XSS的攻击原理、典型利用场景及防御措施,并结合芯片行业特有的EDA工具Web化、供应链平台化等背景,分析XSS在BOM查看器、项目协作平台、晶圆厂管理系统等高敏感环境中的实际风险。文章通过六类代码案例(如搜索回显、输入框属性注入、事件绕过过滤、存储型字段输出、DOM操作漏洞)进行深度审计剖析,提出输出转义、白名单过滤、CSP策略等可落地的防御方案,并展望芯片行业Web安全未来将向默认转义、硬件信任根绑定、AI自动化检测与合规驱动防护发展。; 适合人群:从事芯片行业Web开发、安全审计或运维工作的技术人员,具备一定Web安全基础的研发与安全人员(工作1-3年为佳)。; 使用场景及目标:①掌握xss-labs靶场核心技巧在真实工业场景中的映射与应用;②学会在EDA系统、供应链平台等高价值Web应用中识别和修复XSS漏洞;③构建从代码层到架构层的纵深防御能力; 阅读建议:学习时应结合xss-labs靶场动手实践,对照文中代码案例在模拟环境中复现攻击与防御过程,重点关注输出点控制与转义机制的设计逻辑,并将CSP、HttpOnly等策略纳入日常开发规范。

冲压机构的画法哈哈哈哈

冲压机构的画法哈哈哈哈

冲压机构冲压机构的画法----

数据结构教程第5版练习题答案

数据结构教程第5版练习题答案

Data-Structres 我的博客 :叫我皮卡丘 Stargazers over time 前言 中国大学MOOC上浙大的《数据结构》广受好评,原因有二,一是基础,简单易懂,老师讲得也清楚,另一大优点就是配套的每周相应知识点的编程题了,有难有易,容易题帮助巩固知识点,难题开阔视野。 源码链接: https://pan.quark.cn/s/a4b39357ea24 笔记加入了一些自己的想法,题解也有思路说明 课程地址:https://www.icourse163.org/course/ZJU-93001 现将笔记和题解记录如下 基本概念 基本概念 线性结构 线性表 堆栈 队列 树 树的定义 二叉树的遍历 二叉搜索树 平衡二叉树 堆 哈夫曼树 并查集的实现和优化 图 图的定义 图的遍历 最短路径 最小生成树 排序 排序 散列查找 散列查找 KMP 注:Saving James Bond - Hard Version 和 关键活动 实在没时间做了... 完结撒花,弱弱求个 star~

100个php练习项目-下载即用.zip

100个php练习项目-下载即用.zip

源码链接: https://pan.quark.cn/s/f9408b22ae4f 有了这个列表,程序员不愁没练手的小项目了 初衷 这个列表原本首发在伯乐在线的一篇译文。 2016年9月21日,该文章推送到微信公众号 程序员的那些事 (ID: iProgrammer ) 后,@BleethNie 留言建议把这 120+ 练手小项目统一放在一个地方,同时其他人可以把自己完成项目提交合并到一起,相互参考学习。 于是我们在 创建了这个项目。 后续会以超链的形式合并大家提交的成果到这个列表。 欢迎 fork & star,并扩散给更多人。 下面列出 120 多个项目构思,根据主题分成了 10 个分类。 文本操作 逆转字符串——输入一个字符串,将其逆转并输出。 拉丁猪文字游戏——这是一个英语语言游戏。 基本规则是将一个英语单词的第一个辅音音素的字母移动到词尾并且加上后缀-ay(譬如“banana”会变成“anana-bay”)。 可以在维基百科上了解更多内容。 统计元音字母——输入一个字符串,统计处其中元音字母的数量。 更复杂点的话统计出每个元音字母的数量。 判断是否为回文——判断用户输入的字符串是否为回文。 回文是指正反拼写形式都是一样的词,譬如“racecar”。 统计字符串中的单词数目——统计字符串中单词的数目,更复杂的话从一个文本中读出字符串并生成单词数目统计结果。 文本编辑器——记事本类型的应用,可以打开、编辑、保存文本文档。 可以增加单词高亮和其它的一些特性。 RSS源创建器——可以从其它来源读取文本并将其以RSS或者Atom的格式发布出去。 实时股价——可以查询股票当前价格。 用户可以设定数据刷新频率,程序会用绿色和红色的箭头表示股价走势。 访客留言簿/日志——允许人们添加评...

Swift-ImageCarouselView(图片轮播).zip

Swift-ImageCarouselView(图片轮播).zip

Swift-ImageCarouselView(图片轮播).zip

befor-torque

befor-torque

my torque report ,thank

constantfolding补丁1653

constantfolding补丁1653

constantfolding补丁1653

网络安全基于XSS-Labs靶场的芯片供应链安全防御体系构建:从漏洞原理到Web应用防护实践

网络安全基于XSS-Labs靶场的芯片供应链安全防御体系构建:从漏洞原理到Web应用防护实践

内容概要:本文探讨了xss-labs靶场通关实战技术在芯片行业中的应用,重点分析如何通过学习XSS漏洞原理提升芯片供应链相关系统的安全性。文章从XSS的基本概念出发,结合芯片行业特有的EDA云平台、IP核授权系统、晶圆厂MES系统等场景,系统讲解了反射型、存储型和DOM型XSS的攻击机制与防御策略。并通过Level 6存储型XSS的代码案例,深入剖析了漏洞成因、攻击载荷构造及三层防御体系(输入验证、内容清洗、输出编码)的构建方法,强调纵深防御理念在保护高价值芯片设计资产中的关键作用。最后展望了AI检测、硬件级防御和供应链协同防护等未来方向。; 适合人群:具备Web安全基础知识,从事芯片设计、半导体信息安全或供应链安全管理的技术人员,以及关注工业级Web应用安全的研发与运维人员。; 使用场景及目标:①提升芯片行业Web系统(如EDA平台、IP交易系统)对XSS攻击的防御能力;②防止敏感设计数据泄露、会话劫持与硬件木马植入;③构建覆盖芯片研发全流程的安全防护体系; 阅读建议:学习过程中应结合xss-labs靶场实际操作,重点关注不同上下文环境下的Payload构造与防御绕过技术,并将所学迁移至芯片行业真实系统中进行渗透测试与安全加固实践。

【最新版】 IPC_JEDEC_j-std-075b-2026.pdf

【最新版】 IPC_JEDEC_j-std-075b-2026.pdf

【最新版】 IPC_JEDEC_j-std-075b-2026

React Native社交应用

React Native社交应用

React Native社交应用

电子工程SOT-23封装双极性晶体管技术参数:SS8550互补型三极管最大额定值与电特性分析

电子工程SOT-23封装双极性晶体管技术参数:SS8550互补型三极管最大额定值与电特性分析

内容概要:本文介绍了SOT-23封装的塑料晶体管的技术参数与特性,包括其最大额定值、电气特性和小信号特性。该晶体管具有40V的集电极-基极电压、25V的集电极-发射极电压以及1.5A的集电极电流能力,功耗为300mW。器件符合RoHS标准且无卤素,适用于高可靠性应用。文档提供了详细的电气性能数据,如击穿电压、截止电流、直流电流增益(hFE)和饱和电压,并附有不同温度下的特性曲线图。此外,还列出了封装尺寸、推荐焊盘布局及订购信息。; 适合人群:电子工程技术人员、硬件设计工程师、元器件采购人员以及从事半导体器件应用开发的相关专业人员。; 使用场景及目标:①用于模拟和数字电路中作为开关或放大元件的设计选型参考;②帮助工程师理解该晶体管在不同温度和负载条件下的电气行为;③为PCB布局提供精确的封装尺寸和焊盘设计依据;④支持产品批量采购时的型号识别与包装选择。; 阅读建议:此资料技术性强,建议结合实际电路设计需求查阅关键参数,重点关注最大额定值、热阻和增益分类,避免超限使用。同时应参考特性曲线进行温升和稳定性分析,确保设计可靠性。

 GBT 12334-2001 金属和其他非有机覆盖层关于厚度测量的定义和一般规则 标准.rar

GBT 12334-2001 金属和其他非有机覆盖层关于厚度测量的定义和一般规则 标准.rar

GBT 12334-2001 金属和其他非有机覆盖层关于厚度测量的定义和一般规则 标准.rar

 JIS C5016-1994-r2004-eng.rar

JIS C5016-1994-r2004-eng.rar

JIS C5016-1994-r2004-eng.rar

云原生技术栈技术汇总 2026-05-22

云原生技术栈技术汇总 2026-05-22

云原生技术栈技术汇总 2026-05-22

 GBT 19212.1-2023 IEC 6155-1 .rar

GBT 19212.1-2023 IEC 6155-1 .rar

GBT 19212.1-2023 IEC 6155-1 .rar

Bootstrap5卡片布局:响应式卡片组与瀑布流

Bootstrap5卡片布局:响应式卡片组与瀑布流

卡片组是Bootstrap5常用布局,用于展示多个同等重要的内容(商品、文章、用户信息),核心用法:1. 卡片组容器:card-group类,实现卡片等高、间距均匀;2. 响应式适配:结合栅格系统(如row-cols-md-3),实现移动端单列、中等屏幕以上3列布局;3. 卡片样式:给卡片添加bg-*主题色、shadow阴影、img-top图片,丰富展示效果;4. 布局变体:card-deck类(卡片间距更大)、card-columns类(瀑布流布局,自动适配内容高度),适配不同内容展示需求,提升页面美观度。 24直播网:sjbappvip.org 24直播网:shijiebeiqiu.org 24直播网:m.2026shijiebei1app.org 24直播网:sjbapp24h.org 24直播网:m.sjbappvip.org

最新推荐最新推荐

recommend-type

物联网学习篇1:Python SDK接入阿里云物联网平台,接收服务端订阅消息

这个过程涉及到SDK的下载、安装、验证,以及配置和运行Python脚本来实现与物联网平台的交互。对于想要涉足物联网领域的Python程序员来说,这是一个重要的起点。在后续的学习中,你可能会接触到设备注册、数据上报、...
recommend-type

TimescaleDB的介绍

1. 时序数据出现越来越多的地方:监控和 DevOps,传感器数据和物联网,财务数据,物流数据,应用程序使用数据,等等。 2. 需要规模和查询能力:时序数据需要规模和查询能力,但这两个属性难以捉摸。 3. 需要统一...
recommend-type

Python使用线程来接收串口数据的示例

在Python编程中,有时我们需要实时地从串口(Serial Port)接收数据,特别是在处理硬件设备交互、物联网(IoT)项目或嵌入式系统通信时。为了实现这一目标,我们可以利用多线程技术来确保程序的高效运行。本文将详细...
recommend-type

计算机网络(物联网)课程设计《智能家居协议设计》,使用socket编程,附规范报告及python源码

本项目旨在设计一个物联网智能家居系统,采用Python的socket编程实现服务器与客户端的通信。系统包括一个物联网服务器(上位机)和多个客户端(下位机),模拟不同的智能家居设备如温度传感器、湿度传感器、灯光、...
recommend-type

基于ZIGBEE协议栈的多种传感器数据采集与控制.docx

本文主要探讨了一种基于ZigBee协议栈的嵌入式无线传感器网络设计,用于实现多种传感器数据的无线采集与控制。设计中采用CC2530微控制器作为核心,适用于资源有限的嵌入式系统,能适应各种环境下的物理层技术。ZigBee...
recommend-type

学生成绩管理系统C++课程设计与实践

资源摘要信息:"学生成绩信息管理系统-C++(1).doc" 1. 系统需求分析与设计 在进行学生成绩信息管理系统开发前,首先需要进行系统需求分析,这是确定系统开发目标与范围的过程。需求分析应包括数据需求和功能需求两个方面。 - 数据需求分析: - 学生成绩信息:需要收集学生的姓名、学号、课程成绩等数据。 - 数据类型和长度:明确每个数据项的数据类型(如字符串、整型等)和长度,例如学号可能是字符串类型且长度为一定值。 - 描述:详细描述每个数据项的意义,以确保系统能够准确处理。 - 功能需求分析: - 列出功能列表:用户界面应提供清晰的操作指引,列出所有可用功能。 - 查询学生成绩:系统应能通过学号或姓名查询学生的成绩信息。 - 增加学生成绩信息:允许用户添加未保存的学生成绩信息。 - 删除学生成绩信息:能够通过学号或姓名删除已经保存的成绩信息。 - 修改学生成绩信息:通过学号或姓名修改已有的成绩记录。 - 退出程序:提供安全退出程序的选项,并确保所有修改都已保存。 2. 系统设计 系统设计阶段主要完成内存数据结构设计、数据文件设计、代码设计、输入输出设计、用户界面设计和处理过程设计。 - 内存数据结构设计: - 使用链表结构组织内存中的数据,便于动态增删查改操作。 - 数据文件设计: - 选择文本文件存储数据,便于查看和编辑。 - 代码设计: - 根据功能需求,编写相应的函数和模块。 - 输入输出设计: - 设计简洁明了的输入输出提示信息和操作流程。 - 用户界面设计: - 用户界面应为字符界面,方便在命令行环境下使用。 - 处理过程设计: - 设计数据处理流程,确保每个操作都有明确的处理逻辑。 3. 系统实现与测试 实现阶段需要根据设计阶段的成果编写程序代码,并进行系统测试。 - 程序编写: - 完成系统设计中所有功能的程序代码编写。 - 系统测试: - 设计测试用例,通过测试用例上机测试系统。 - 记录测试方法和测试结果,确保系统稳定可靠。 4. 设计报告撰写 最后,根据系统开发的各个阶段,撰写详细的设计报告。 - 系统描述:包括问题说明、数据需求和功能需求。 - 系统设计:详细记录内存数据结构设计、数据文件设计、代码设计、输入/输出设计、用户界面设计、处理过程设计。 - 系统测试:包括测试用例描述、测试方法和测试结果。 - 设计特点、不足、收获和体会:反思整个开发过程,总结经验和教训。 时间安排: - 第19周(7月12日至7月16日)完成项目。 - 7月9日8:00到计算机学院实验中心(三楼)提交程序和课程设计报告。 指导教师和系主任(或责任教师)需要在文档上签名确认。 系统需求分析: - 使用表格记录系统需求分析的结果,包括数据项、数据类型、数据长度和描述。 - 分析数据项如学生成绩信息、状态器、链表节点等,确定其属性和行为。 以上就是文档中提到的学生成绩信息管理系统开发的关键知识点。开发此类系统需要熟练掌握C++编程基础,了解面向对象的程序设计思想,以及熟悉文件操作和链表等数据结构的应用。此外,良好的软件开发流程意识、测试意识和文档撰写能力也是必不可少的。
recommend-type

别再手动拖拽了!用Lumerical脚本批量创建FDTD仿真结构(附完整代码)

# 告别低效建模:Lumerical脚本自动化实战指南 在光子学仿真领域,时间就是科研生命线。当同行还在GUI界面里反复点击菜单时,你已经用脚本批量生成了20组参数化结构——这不是未来场景,而是每位FDTD用户都应该掌握的基础生产力革命。本文将彻底改变你与Lumerical的交互方式,从手动拖拽的农耕时代,跃迁到自动化建模的工业文明。 ## 1. 为何脚本建模是必然选择 2019年Nature Photonics的一项研究显示,科研工作者在仿真工具上平均浪费37%的时间在重复性操作上。对于需要参数扫描的纳米光学结构设计,这个数字可能更高。手动创建10个不同尺寸的纳米柱阵列意味着: -
recommend-type

Java邮件解析任务中,如何安全高效地提取HTML邮件内容并避免硬编码、资源泄漏和类型转换异常?

<think>我们被要求优化一段Java代码,该代码用于处理邮件(特别是来自特定发件人的构建通知邮件)。代码的主要问题包括: 1. 重复获取邮件内容:在检查MIME类型后,多次调用`msg[i].getContent()`,这可能导致性能问题或流关闭异常。 2. 类型转换问题:直接将邮件内容转换为`Multipart`而不进行类型检查,可能引发`ClassCastException`。 3. 代码结构问题:逻辑嵌套过深,可读性差,且存在重复代码(如插入邮件详情的操作在两个地方都有)。 4. 硬编码和魔法值:例如在解析HTML表格时使用了硬编码的索引(如list3.get(10)),这容易因邮件
recommend-type

RH公司应收账款管理优化策略研究

资源摘要信息:"本文针对RH公司的应收账款管理问题进行了深入研究,并提出了改进策略。文章首先分析了应收账款在企业管理中的重要性,指出其对于提高企业竞争力、扩大销售和充分利用生产能力的作用。然后,以RH公司为例,探讨了公司应收账款管理的现状,并识别出合同管理、客户信用调查等方面的不足。在此基础上,文章提出了一系列改善措施,包括完善信用政策、改进业务流程、加强信用调查和提高账款回收力度。特别强调了建立专门的应收账款回收部门和流程的重要性,并建议在实际应用过程中进行持续优化。同时,文章也意识到企业面临复杂多变的内外部环境,因此提出的策略需要根据具体情况调整和优化。 针对财务管理领域的专业学生和从业者,本文提供了一个关于应收账款管理问题的案例研究,具有实际指导意义。文章还探讨了信用管理和征信体系在应收账款管理中的作用,强调了它们对于提升企业信用风险控制和市场竞争能力的重要性。通过对比国内外企业在应收账款管理上的差异,文章总结了适合中国企业实际环境的应收账款管理方法和策略。" 根据提供的文件内容,以下是详细的知识点: 1. 应收账款管理的重要性:应收账款作为企业的一项重要资产,其有效管理关系到企业的现金流、财务健康以及市场竞争力。不良的应收账款管理会导致资金链断裂、坏账损失增加等问题,严重影响企业的正常运营和长远发展。 2. 应收账款的信用风险:在信用交易日益频繁的商业环境中,企业必须对客户信用进行评估,以便采取合理的信用政策,降低信用风险。 3. 合同管理的薄弱环节:合同是应收账款管理的法律基础,严格的合同管理能够保障企业权益,减少因合同问题导致的应收账款风险。 4. 客户信用调查:了解客户的信用状况对于预测和控制应收账款风险至关重要。企业需要建立有效的客户信用调查机制,识别和筛选信用良好的客户。 5. 应收账款回收策略:企业应建立有效的账款回收机制,包括定期的账款跟进、逾期账款的催收等。同时,建立专门的应收账款回收部门可以提升回收效率。 6. 应收账款管理流程优化:通过改进企业内部管理流程,如简化审批流程、提高工作效率等措施,能够提升应收账款的管理效率。 7. 应收账款管理策略的调整和优化:由于企业的内外部环境复杂多变,因此制定的管理策略需要根据实际情况进行动态调整和持续优化。 8. 信用管理和征信体系的作用:建立和完善企业内部信用管理体系和征信体系,有助于企业更好地控制信用风险,并在市场竞争中占据有利地位。 9. 对比国内外应收账款管理实践:通过研究国内外企业在应收账款管理上的不同做法和经验,可以借鉴先进的管理理念和方法,提升国内企业的应收账款管理水平。 综上所述,本文深入探讨了应收账款管理的多个方面,为RH公司乃至其他同类型企业提供了应收账款管理的改进方向和策略,对于财务管理专业的教育和实践都具有重要的参考价值。
recommend-type

新手别慌!用BingPi-M2开发板带你5分钟搞懂Tina Linux SDK目录结构

# 新手别慌!用BingPi-M2开发板带你5分钟搞懂Tina Linux SDK目录结构 第一次拿到BingPi-M2开发板时,面对Tina Linux SDK里密密麻麻的文件夹,我完全不知道从哪下手。就像走进一个陌生的大仓库,每个货架上都堆满了工具和零件,却找不到操作手册。这种困惑持续了整整两天,直到我意识到——理解目录结构比死记硬背每个文件更重要。 ## 1. 为什么SDK目录结构如此重要 想象你正在组装一台复杂的模型飞机。如果所有零件都混在一个箱子里,你需要花大量时间寻找每个螺丝和面板。但如果有分门别类的隔层,标注着"机身部件"、"电子设备"、"紧固件",组装效率会成倍提升。Ti