vb 向DataGridView粘贴excel数据

derrbuex 2015-10-24 07:06:43
在excel中复制了一行或者一个区域的值 如何将他粘贴到DataGridView中 我试了无论在excel中选取多少值只能粘贴到DataGridView的一个单元格中 ,这个问题怎么解决
...全文
376 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
derrbuex 2015-10-25
  • 打赏
  • 举报
回复
引用 4 楼 derrbuex 的回复:
[quote=引用 3 楼 ajianchina 的回复:] 你可以注册一个热键就像ctrl+v,然后在WndProc中拦截这个热键,拦截之后就执行我给的这段代码。 或者你干脆就用一个按钮,点击按钮执行也行,你就将该函数内的代码贴过去就行了。
我试过了没反应 我把代码放在一个按钮下 在excel上复制了一个区域 然后切换到 vb程序 点击按钮没有反应[/quote] 而且有选中datagridview中的单元格
derrbuex 2015-10-25
  • 打赏
  • 举报
回复
引用 3 楼 ajianchina 的回复:
你可以注册一个热键就像ctrl+v,然后在WndProc中拦截这个热键,拦截之后就执行我给的这段代码。 或者你干脆就用一个按钮,点击按钮执行也行,你就将该函数内的代码贴过去就行了。
我试过了没反应 我把代码放在一个按钮下 在excel上复制了一个区域 然后切换到 vb程序 点击按钮没有反应
derrbuex 2015-10-25
  • 打赏
  • 举报
回复
这个不行的 我自己解决了 还是谢谢
ajianchina 2015-10-24
  • 打赏
  • 举报
回复
你可以注册一个热键就像ctrl+v,然后在WndProc中拦截这个热键,拦截之后就执行我给的这段代码。 或者你干脆就用一个按钮,点击按钮执行也行,你就将该函数内的代码贴过去就行了。
derrbuex 2015-10-24
  • 打赏
  • 举报
回复
引用 1 楼 ajianchina 的回复:
从剪贴板取得数据,然后按行列粘贴到datagridview

Private Sub CopyExcelToGrid()
	If datagridview.CurrentCell Is Nothing Then
		Return
	End If
	Dim insertRowIndex As Integer = datagridview.CurrentCell.RowIndex
	'从剪贴板中取得格式本文数据
	Dim pasteText As String = Clipboard.GetText()
	If String.IsNullOrEmpty(pasteText) Then
		Return
	End If
	pasteText = pasteText.Replace(" ", " ")
	pasteText = pasteText.Replace(" "C, " "C)
	pasteText.TrimEnd(New Char() {" "C})
	Dim lines As String() = pasteText.Split(" "C)
	Dim isHeader As Boolean = True
	For Each line As String In lines
		If isHeader Then
			isHeader = False
			Continue For
		End If
		Dim vals As String() = line.Split(" "C)
		If vals.Length - 1 <> datagridview.ColumnCount Then
			Throw New ApplicationException("列数错误")
		End If

		Dim row As DataGridViewRow = datagridview.Rows(insertRowIndex)
		row.HeaderCell.Value = vals(0)
		For i As Integer = 0 To row.Cells.Count - 1
			row.Cells(i).Value = vals(i + 1)
		Next
		insertRowIndex += 1
	Next

	Dim iData As IDataObject = Clipboard.GetDataObject()
	If iData.GetDataPresent(DataFormats.Text) Then
		Dim str As String = DirectCast(iData.GetData(DataFormats.Text), [String])
	End If
End Sub
额...这段代码具体怎么用放在哪个部分,新手不太明白
ajianchina 2015-10-24
  • 打赏
  • 举报
回复
从剪贴板取得数据,然后按行列粘贴到datagridview

Private Sub CopyExcelToGrid()
	If datagridview.CurrentCell Is Nothing Then
		Return
	End If
	Dim insertRowIndex As Integer = datagridview.CurrentCell.RowIndex
	'从剪贴板中取得格式本文数据
	Dim pasteText As String = Clipboard.GetText()
	If String.IsNullOrEmpty(pasteText) Then
		Return
	End If
	pasteText = pasteText.Replace(" ", " ")
	pasteText = pasteText.Replace(" "C, " "C)
	pasteText.TrimEnd(New Char() {" "C})
	Dim lines As String() = pasteText.Split(" "C)
	Dim isHeader As Boolean = True
	For Each line As String In lines
		If isHeader Then
			isHeader = False
			Continue For
		End If
		Dim vals As String() = line.Split(" "C)
		If vals.Length - 1 <> datagridview.ColumnCount Then
			Throw New ApplicationException("列数错误")
		End If

		Dim row As DataGridViewRow = datagridview.Rows(insertRowIndex)
		row.HeaderCell.Value = vals(0)
		For i As Integer = 0 To row.Cells.Count - 1
			row.Cells(i).Value = vals(i + 1)
		Next
		insertRowIndex += 1
	Next

	Dim iData As IDataObject = Clipboard.GetDataObject()
	If iData.GetDataPresent(DataFormats.Text) Then
		Dim str As String = DirectCast(iData.GetData(DataFormats.Text), [String])
	End If
End Sub
内容概要:本文提出一种基于鱼鹰优化算法(OOA)优化的CNN-BiGUR-Attention混合模型,用于提升短期风电功率预测的精度与稳定性,采用Matlab实现代码仿真。该模型融合卷积神经网络(CNN)提取输入数据的局部空间特征,利用双向门控循环单元(BiGUR)捕捉风速、功率等时间序列的前后向动态依赖关系,并引入注意力机制自适应强化关键时间步的特征权重,从而增强模型对非平稳风电数据的表征能力;进一步,采用OOA算法对模型超参数进行全局寻优,有效提升模型收敛速度与泛化性能。研究基于实际风电场历史数据开展实验验证,结果表明,该方法相较传统模型在预测精度、鲁棒性和误差抑制方面表现更优,适用于高比例可再生能源接入背景下的电力系统调度需求。; 适合人群:从事新能源发电预测、电力系统优化调度、智能算法与深度学习融合应用等方向的科研人员及工程技术人员,尤其适合具备Matlab编程能力、熟悉时间序列建模与深度学习框架的研究者。; 使用场景及目标:①实现风电场短期功率高精度预测,支撑电网安全稳定调度与能量管理;②为深度学习模型结构设计与智能优化算法联合调参提供实践范例;③推动人工智能技术在可再生能源预测、智能电网运行等领域的落地应用。; 阅读建议:建议结合提供的Matlab代码深入理解CNN-BiGUR-Attention网络架构搭建、注意力机制实现方式及OOA优化流程,重点关注数据预处理、模型训练与参数调优细节,可通过替换不同风电数据集进行对比实验,进一步掌握模型迁移能力与适应性。

16,718

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧