boxmoe_header_banner_img

Hello! 欢迎来到悠悠畅享网!

文章导读

使用 Python 绘制服务器机架图:文本表格与 HTML 表格方案


avatar
作者 2025年9月4日 8

使用 Python 绘制服务器机架图:文本表格与 HTML 表格方案

本文档旨在提供使用 python 绘制服务器机架图的解决方案。我们将探讨如何将服务器位置数据转换为可用于生成文本表格或 html 表格的格式。通过 tabulate 库创建清晰的文本表格,并展示如何使用 pandas 库或手动方式生成 HTML 表格。此外,还将介绍如何结合 flask 框架,在 Web 应用中动态生成服务器机架图。

数据准备与转换

首先,我们需要将服务器位置数据转换为 Python 可以处理的格式。 假设我们有以下数据:

servers1 - 15 - 17 server2 - 20 - 25 firewall - 2 - 4 NAS - 10 - 15

我们需要将其转换为一个列表,其中每个元素代表机架中的一个 U 位,并包含该 U 位上设备的名称。如果该 U 位为空,则用 “?” 表示。

import io  text = '''servers1 - 15 - 17 server2 - 20 - 25 firewall - 2 - 4 NAS - 10 - 15'''  data = {} counter = {}  with io.StringIO(text) as fh:     for line in fh:         line = line.strip()         name, start, end = line.split(' - ')         start = int(start)         end = int(end)          # - count -         counter[name] = end-start+1          for x in range(start, end+1):             data[x] = name  # - display counter - #print(counter) for name, number in counter.items():     print(f'{name:10}: {number}')  # --- convert to list ---  rows = [] last = max(data.keys())  for x in range(1, last+1):     if x in data:         name = data[x]     else:         name = '?'     rows.append([x, name])  #print(rows)

这段代码首先读取数据,将其解析为设备名称、起始 U 位和结束 U 位。然后,它创建一个字典 data,其中键是 U 位,值是设备名称。如果某个 U 位没有设备,则将其值设置为 “? “。最后,代码将 data 字典转换为一个列表 rows,该列表可以用于生成表格。

生成文本表格

我们可以使用 tabulate 库来生成文本表格。 首先,需要安装 tabulate 库:

pip install tabulate

然后,可以使用以下代码生成文本表格:

import tabulate  print(tabulate.tabulate(rows, headers=['Nr', 'Device'], tablefmt='grid'))

这将生成一个如下所示的文本表格:

+------+----------+ |   Nr | Device   | +======+==========+ |    1 | ?        | +------+----------+ |    2 | firewall | +------+----------+ |    3 | firewall | +------+----------+ |    4 | firewall | +------+----------+ |    5 | ?        | +------+----------+ |    6 | ?        | +------+----------+ |    7 | ?        | +------+----------+ |    8 | ?        | +------+----------+ |    9 | ?        | +------+----------+ |   10 | NAS      | +------+----------+ |   11 | NAS      | +------+----------+ |   12 | NAS      | +------+----------+ |   13 | NAS      | +------+----------+ |   14 | NAS      | +------+----------+ |   15 | NAS      | +------+----------+ |   16 | servers1 | +------+----------+ |   17 | servers1 | +------+----------+ |   18 | ?        | +------+----------+ |   19 | ?        | +------+----------+ |   20 | server2  | +------+----------+ |   21 | server2  | +------+----------+ |   22 | server2  | +------+----------+ |   23 | server2  | +------+----------+ |   24 | server2  | +------+----------+ |   25 | server2  | +------+----------+

生成 HTML 表格

使用 pandas

如果使用 pandas 库,则可以轻松地将 rows 列表转换为 HTML 表格。 首先,需要安装 pandas 库:

pip install pandas

然后,可以使用以下代码生成 HTML 表格:

import pandas as pd  df = pd.DataFrame(rows, columns=['Nr', 'Device']) html_table = df.to_html() print(html_table)

这将生成一个 HTML 表格字符串,可以直接嵌入到 HTML 页面中。

手动生成 HTML 表格

如果不使用 pandas,也可以手动生成 HTML 表格。可以使用以下代码:

table = "<table>n"  table += "  <tr>n    <th>Nr</th>n    <th>Device</th>n  </tr>n"  for number, device in rows:     table += f"  <tr>n    <td>{number}</td>n    <td>{device}</td>n  </tr>n"  table += "</table>n"  print(table)

这将生成与 pandas 版本相同的 HTML 表格。

结合 Flask 框架

如果需要在 Web 应用程序中显示服务器机架图,可以使用 Flask 框架。 首先,需要安装 Flask 框架:

pip install flask

然后,可以使用以下代码创建一个简单的 Flask 应用程序:

from flask import Flask, render_template  app = Flask(__name__)  @app.route('/') def index():     # 从上面的代码中获取 rows 列表     import io      text = '''servers1 - 15 - 17     server2 - 20 - 25     firewall - 2 - 4     NAS - 10 - 15'''      data = {}     counter = {}      with io.StringIO(text) as fh:         for line in fh:             line = line.strip()             name, start, end = line.split(' - ')             start = int(start)             end = int(end)              # - count -             counter[name] = end-start+1              for x in range(start, end+1):                 data[x] = name      # - display counter -     #print(counter)     for name, number in counter.items():         print(f'{name:10}: {number}')      # --- convert to list ---      rows = []     last = max(data.keys())      for x in range(1, last+1):         if x in data:             name = data[x]         else:             name = '?'         rows.append([x, name])      return render_template('template.html', rows=rows)  if __name__ == '__main__':     app.run(debug=True)

在这个例子中,index 函数将 rows 列表传递给名为 template.html 的模板。template.html 文件的内容如下:

<!DOCTYPE html> <html> <head>     <title>服务器机架图</title> </head> <body>     <table>         <tr>             <th>Nr</th>             <th>Device</th>         </tr>         {% for number, device in rows %}         <tr>             <td>{{ number }}</td>             <td>{{ device }}</td>         </tr>         {% endfor %}     </table> </body> </html>

这个模板使用 Jinja2 模板引擎来循环遍历 rows 列表,并生成 HTML 表格。

总结

本文档介绍了使用 Python 绘制服务器机架图的几种方法,包括生成文本表格和 HTML 表格。我们还介绍了如何结合 Flask 框架,在 Web 应用程序中动态生成服务器机架图。根据实际需求选择合适的方法,可以有效地管理和可视化服务器机架资源。



评论(已关闭)

评论已关闭