excel表格中,我要在当A1输入内容时,则b1自动填充当天的日期

2024-11-26 20:37:14
推荐回答(5个)
回答1:

要用 VBA , 或者 迭代运算  可能有点用,  写VBA的话, WPS  用不了:

Excel 内  右键   点工作表 名字--查看代码,如下代码 复制进去,存为启用宏的工作薄,启用宏可使用:

Private Sub Worksheet_Change(ByVal Target As Range)
  On Error Resume Next
  If Target.Column = 1 Then  '如果当前编辑单元格在第1列 A列
     If Target <> "" Then
      Target.Offset(0, 1) = Date    '当前单元格右边一格 =日期
      Else
      Target.Offset(0, 1) = ""  '如果清空 内容则右边一格 清空
     End If
  End If
End Sub

回答2:

在菜单的 工具\选项\重新计算 勾选【迭代计算】 【最多迭代次数】后填:1,确定。
在B1里写公式:
=IF(A1="","",IF(OR(B1="",B1=0),TODAY(),B1))
向下拖动复制。OK
去试一试吧!!!祝你成功!!!!

回答3:

b1=if(a1<>"",today(),"")
系统时间变化之前时间不变,可以复制粘贴为数值就可以了

回答4:

是用VBA代码吧。假设你要加入这个功能到你的工作簿的 sheet1 工作表中,那么 alt + F11,然后在左边工程中,找到你所在的工作簿,然后在下面的EXCEL对象中找到 SHEET1,双击它,在弹出的窗口中,将以下代码,粘贴进去。就可以实现你的功能了。(a列如有改动,b列对应的位置就输入日期。)

Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Address Like "$[A]$*" Then Cells(Target.Row, 2) = Format(Now(), "YYYY-MM-DD")
End Sub

回答5:

楼上说的还是蛮好用的,建议使用