xyy_82216 发表于 2006-6-7 14:14:00

关于datagrid数据控件的问题,捆饶很久了~~

vba中,选中datagrid中的一条记录,怎么把这条记录的每个字段分别属给象应的变量!!比如说,被选中的这条记录的第一个字段属给x1 第二个字段属给y1。。。。。。怎么做呢,请高手们帮帮忙,小弟在此谢过了。。。

xinghesnak 发表于 2006-6-7 15:31:00

<P>对datagrid控件不甚了解,紧紧知道能这样得到数据。</P>
<P>Private&nbsp;Sub&nbsp;Command1_Click()<BR>&nbsp;&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp;&nbsp;&nbsp;DataGrid1.Row&nbsp;=&nbsp;1&nbsp;&nbsp;&nbsp;&nbsp;'定位DataGrid1行<BR>&nbsp;&nbsp;&nbsp;&nbsp;DataGrid1.Col&nbsp;=&nbsp;1&nbsp;&nbsp;&nbsp;&nbsp;'定位DataGrid1列<BR>&nbsp;&nbsp;&nbsp;&nbsp;MsgBox&nbsp;DataGrid1.Text'取得1984<BR>&nbsp;&nbsp;&nbsp;&nbsp;<BR>End&nbsp;Sub</P>
<P>如果先选择行再得到数据就不知道了,得向高手请教了!不过多说一句,这个控件不是很好用,只能绑定数据库。不如MSFlexGrid控件顺手。。。。。。。</P>

xinghesnak 发表于 2006-6-7 15:44:00

dynacy 发表于 2006-6-7 21:06:00

<P>这个问题我在VB中是利用了Listbox控件解决的,想必你对这个通用控件要熟悉的多吧。先把每个字段的值读到列表框里,然后,你就可以用它的属性list来取得数据拉</P>
<P>dim rs2 as recordset</P>
<P>Set rs2 = db.OpenRecordset("设计线数据") '表名<BR>Do While Not rs2.EOF<BR>&nbsp;&nbsp;&nbsp; frmwll.List3.additem rs2.Fields(1).Value<BR>&nbsp;&nbsp; frmwll.List4.additem rs2.Fields(2).Value<BR>&nbsp;&nbsp; frmwll.List5.additem rs2.Fields(3).Value<BR>&nbsp;&nbsp;&nbsp; frmwll.List15.additem rs2.Fields(4).Value<BR>&nbsp;&nbsp; frmwll.List16.additem rs2.Fields(5).Value<BR>&nbsp;&nbsp; frmwll.List17.additem rs2.Fields(6).Value<BR>&nbsp;&nbsp; frmwll.List18.additem rs2.Fields(7).Value<BR>&nbsp;&nbsp; rs2.MoveNext<BR>Loop<BR>rs2.Close</P>
<P>比如你取第一个字段的第三个值,则可用list3.list(2)取到。</P>

xyy_82216 发表于 2006-6-8 12:58:00

<P>谢谢朋友们,我是这样解决的</P>
<P>Private Sub DataGrid1_MouseUp(ByVal Button As Integer, ByVal Shift As Integer, ByVal X As stdole.OLE_XPOS_PIXELS, ByVal Y As stdole.OLE_YPOS_PIXELS)</P>
<P>x1 = Val(DataGrid1.Columns.Item(1))</P>
<P>end sub </P>
<P>就是点选一行,当鼠标释放的时候,把里面每个字段属给一个变量,这些变量去全局变量,这样就可以在其它过程中用这些变量了,我不知道这样对不对,不过我在实验的过程中,都能把相应的值给取出来,然后属给一个变量,这样也能利用取出的值画图了~~</P>
<P>这样可以么?</P>

wyj7485 发表于 2006-8-9 10:59:00

本帖最后由 作者 于 2006-8-11 11:50:19 编辑 <br /><br /> <P>这种很好用</P>
<P>Private Sub DataGrid1_RowColChange(LastRow As Variant, ByVal LastCol As Integer)<BR>DataStr&nbsp;= DataGrid1.Text'获得鼠标点的数据</P>
<P>n=DataGrid1.Row'获得该数据行号</P>
<P>m=DataGrid1.col'获得该数据列号</P>
<P>End Sub</P>
页: [1]
查看完整版本: 关于datagrid数据控件的问题,捆饶很久了~~