代码拉取完成,页面将自动刷新
import pandas as pd
import matplotlib.pyplot as plt
from sklearn.cluster import KMeans
from sklearn.preprocessing import StandardScaler
# 加载日志数据
log_data = pd.read_csv('data.csv')
# 计算每对源IP和目的IP的连接次数
connection_counts = log_data.groupby(['src_ip', 'dst_ip', 'dst_port']).size().reset_index(name='count')
# 标准化连接次数特征数据
scaler = StandardScaler()
scaled_counts = scaler.fit_transform(connection_counts[['count']])
# 调用聚类算法(这里使用K均值聚类,请根据需要选择合适的聚类算法)
k = 8
kmeans = KMeans(n_clusters=k, random_state=0, n_init='auto')
kmeans.fit(scaled_counts)
labels = kmeans.labels_
# print(labels)
cluster_centers = kmeans.cluster_centers_
# print(cluster_centers)
result = connection_counts
result['label'] = pd.DataFrame(labels)
print(result)
result.to_csv("kmeans.csv", encoding = 'utf-8')
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。