插入空白单元格

插入空白单元格

需求

  1. 去重后的数据在每一个单元格下插入指定的空白行
  2. 实现的示意视频

方案思路

  1. 选中一列单元格区域,然后从下方插入,为保证插入的空白在被插入单元格的下方,需要从被插入单元格的下方开始插入

代码实现

Sub insert_blank()
'在选中的单元格区域的每行下插入指定数量的空白行
    On Error GoTo a
    Set rng = Application.InputBox(prompt:="请选择需要插入空白单元格的连续区域?", Title:="输入框", Default:=Selection.Address, Type:=8) '选择单元格区域
a:
    
    If TypeName(rng) <> "Range" Then
        Exit Sub
    End If
    add1 = rng.Address
    arr1 = Split(Join(Split(add1, ":"), ""), "$")
    n = Application.InputBox(prompt:="想插入几行空白单元格?", Title:="输入框", Type:=1)
    If n = "False" Then
        Exit Sub
    End If
    For i = arr1(4) + 1 To arr1(2) + 1 Step -1
        For j = 1 To n
            Range(arr1(1) & CStr(i) & ":" & arr1(3) & CStr(i)).Insert shift:=xlDown  '插入单元格,活动单元格向下移动
        Next
    Next
End Sub

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 `QTableWidget` 中,如果单击了空白单元,可能会导致程序崩溃,这是因为 `QTableWidget` 并没有默认处理这种情况的方法。解决这个问题的方法是在程序中添加一个 `itemSelectionChanged` 信号的槽函数,并在该槽函数中处理空白单元的情况。以下是一个示例代码: ```python from PyQt5.QtWidgets import QMainWindow, QTableWidget, QApplication, QTableWidgetItem class MainWindow(QMainWindow): def __init__(self): super().__init__() self.table_widget = QTableWidget() self.table_widget.itemSelectionChanged.connect(self.handle_item_selection_changed) self.setCentralWidget(self.table_widget) # 添加表内容 self.table_widget.setRowCount(5) self.table_widget.setColumnCount(5) for i in range(5): for j in range(5): item = QTableWidgetItem('Item {}-{}'.format(i, j)) self.table_widget.setItem(i, j, item) def handle_item_selection_changed(self): selected_items = self.table_widget.selectedItems() if len(selected_items) == 0: print('No item selected') else: selected_item = selected_items[0] row = selected_item.row() column = selected_item.column() item_text = selected_item.text() print('Selected item:', item_text, 'at row', row, 'and column', column) ``` 在上面的代码中,我们为 `QTableWidget` 的 `itemSelectionChanged` 信号设置了一个槽函数 `handle_item_selection_changed`。当用户选择或取消选择表中的任何一个单元时,该槽函数将被调用。在该槽函数中,我们首先获取当前选择的所有单元,如果没有单元被选择,则打印出 "No item selected" 的信息。否则,我们获取第一个选择的单元的行、列和文本内容,并打印出这些信息。这样,即使用户单击空白单元,程序也不会崩溃。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值