k-means

 

k-means 是一种无监督的迭代求解的聚类分析算法,其步骤是将数据分成k个聚类,随机选择k个点作为作为初始的聚类中心,计算各个数据到中心的距离,然后分配数据给最近的聚类中心。之后每次分配都会重新计算聚类中心,重新分配,不断迭代,直到某个条件(聚类中心不再变化或无数据需要被分配等)终止。

创建num个数据,大小从x-y

def create_data(num,x,y):

    a = np.random.randint(x, y, size=[num, 2])

    # print(points)
    x = a[:,0]
    y = a[:,1]
    return x,y,a

产生最初的中心点

def initCent(points,k):
    numSamples, dim = points.shape
    print(points.shape)
    centroids = np.zeros((k, dim))
    for i in range(k):
        index = int(random.uniform(0, numSamples))
        centroids[i] = points[index]
    return centroids

计算中心点到各个数据点的距离

def distance(points, centroids, k):
    clalist=[]
    for data in points:
        diff = np.tile(data, (k, 1)) - centroids  #相减   (np.tile(a,(2,1))就是把a先沿x轴复制1倍,即没有复制,仍然是 [0,1,2]。 再把结果沿y方向复制2倍得到array([[0,1,2],[0,1,2]]))
        squaredDiff = diff ** 2     #平方
        squaredDist = np.sum(squaredDiff, axis=1)   #和  (axis=1表示行)
        distance = squaredDist ** 0.5  #开根号
        clalist.append(distance)
    clalist = np.array(clalist)  #返回一个每个点到质点的距离len(dateSet)*k的数组
    return clalist

重新计算中心点

def rezhi(points,cent,k):
    dis  = distance(points,cent,k)
    minDistIndices = np.argmin(dis, axis=1)
    newCentroids = pd.DataFrame(points).groupby(minDistIndices).mean()
    newCentroids = newCentroids.values

    change = newCentroids - cent
    return change,newCentroids

最后:

def k_mean(points,k,cent):
    chang,newcen = rezhi(points,cent,k)
    while np.any(chang!=0):
        chang, newcen = rezhi(points, newcen, k)
    centroids = sorted(newcen.tolist())
    cluster = []
    dis = distance(points, newcen, k)
    minDistIndices = np.argmin(dis, axis=1)
    print(minDistIndices)
    for i in range(k):
        cluster.append([])
    for i, j in enumerate(minDistIndices):  # enymerate()可同时遍历索引和遍历元素
        cluster[j].append(points[i])
    return centroids, cluster,minDistIndices

if __name__ == '__main__':
    x,y,points= create_data(100,1,100)
    k = 3
    print(points)
    p = initCent(points,k)
    d = distance(points,p,k)
    print(d)
    c,n = rezhi(points,p,k)
    centroids, cluster,t = k_mean(points, k,p)
    print('质心为:%s' % centroids)
    print('集群为:%s' % cluster)
    plt.scatter(x, y, label='First')
    for j in range(len(centroids)):
        plt.scatter(centroids[j][0], centroids[j][1], marker='x', color='red', s=50, label='质心')
        plt.show
    color = ['maroon','blue','black','green','yellow','gray']
    for j in range(len(cluster)):
        for i in range(len(cluster[j])):
            plt.scatter(cluster[j][i][0], cluster[j][i][1], marker='o', color=color[j], s=50, label='集群')
    plt.show()

 

<think>好的,用户想知道如何在Word中将英文小写字母转换为大写。首先,我需要回忆一下自己知道的Word功能。常用的方法可能有使用快捷键,或者通过菜单栏的字体设置来更改大小写。对了,我记得Shift+F3这个快捷键可以在不同的大小写格式之间切换,比如全大写、全小写或者首字母大写。这个应该适用于选中的文本。 另外,用户可能需要更细的操作步骤。比如,在菜单栏中找到“开始”选项卡,然后点击“字体”组里的“更改大小写”按钮,选择“大写”选项。这种方法对于不熟悉快捷键的用户来说更直观。还有,如果用户需要批量处理多个段落或整个文档,可能需要使用查找和替换功能,或者编写宏来自动化操作。不过根据用户提供的引用,他们可能对VBA宏比较感兴趣,因为引用[3]提到了用VBA创建宏来处理金额转换。虽然问题不是关于数字而是英文大小写,但也许可以建议使用宏来处理更复杂的转换需求。 需要注意用户是否提到了具体的Word版本,但问题中没有说明,所以需要给出通用方法,适用于大多数版本。同时,检查是否有其他方法,比如使用Word的公式功能或者插件,但常见的方法还是上述几种。还要确保步骤清晰,避免遗漏关键点,比如选中文本后再操作。另外,提醒用户注意全角半角的问题,但可能用户只是简单转换,不需要涉及这些细节。总结下来,回答应包括快捷键、菜单操作,以及可能的VBA方法,并引用提供的参考资料中的相关部分,比如引用[3]的宏示例,虽然内容不同,但可以类比说明宏的可行性。</think>在Microsoft Word中,将英文小写字母转换为大写的常用方法有以下三种,操作步骤清晰且适用于大多数Word版本: ### 方法一:快捷键转换(推荐) 1. 选中需要转换的英文文本 2. 按下组合键$Shift+F3$ 3. 连续按会循环切换三种格式: - 首字母大写(如:"example" → "Example") - 全大写(如:"example" → "EXAMPLE") - 全小写(如:"EXAMPLE" → "example") ### 方法二:菜单栏操作 1. 选中目标文本 2. 点击「开始」选项卡 →「字体」组中的「更改大小写」按钮(Aa标) 3. 在下拉菜单中选择「大写」 ### 方法三:VBA宏批量转换(适合批量处理) 1. 按$Alt+F11$打开VBA编辑器 2. 插入新模块并粘贴以下代码: ```vba Sub ConvertToUpperCase() Selection.Range.Case = wdUpperCase End Sub ``` 3. 返回Word文档,选中文本后运行宏即可转换(可自定义快捷键绑定) 如果需要处理复杂格式或特殊需求,可以参考类似数字转换中文大写的宏实现思路[^3],通过修改VBA代码实现更智能的转换功能。对于常规使用,前两种方法已足够高效,快捷键转换效率最佳,处理500字文档仅需3秒即可完成格式转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值