MapInfo属性表编辑.ppt

上传人:tia****nde 文档编号:11497091 上传时间:2020-04-25 格式:PPT 页数:52 大小:736.50KB
返回 下载 相关 举报
MapInfo属性表编辑.ppt_第1页
第1页 / 共52页
MapInfo属性表编辑.ppt_第2页
第2页 / 共52页
MapInfo属性表编辑.ppt_第3页
第3页 / 共52页
点击查看更多>>
资源描述
第三讲属性表编辑,授课人:邓岳川E-mail:dengyuechuan,表中的图形对象是对地理空间事物的表达,而属性表能够记录有关空间地物信息更为丰富、更为深层次的信息,它对于区域统计分析起到很重要的作用。,3.属性表编辑,1、更新列2、在表中添加行3、表链接4、紧缩表,1.更新列,“更新列”是对属性表进行编辑的一项重要操作,它可以通过值或函数表达式将表中的部分或所有记录更新。,操作步骤:,1)如果当前表中没有要存放相应数据的列,则通过修改表结构(“表”菜单-维护-表结构)来增加相应的字段(即数据列)。在修改表结构的过程中,对于字段的数据类型设置要与存放的数据类型符合,如图3-1。,2)选中要修改的记录,如果要更新的列涉及了表中的所有记录,则不需选中表中的任何记录。3)点击“表”菜单下的“更新列”命令,弹出“更新列”窗口,如图3-2。,4)设置“更新列”窗口,其中要设置的栏包含如下五项:“要更新的表”栏:该栏要用户设定要更新的表的名字。“要更新的列”栏:该栏要用户设定要更新的列的名字;“从中获得值的表”栏:如果更新列的过程中获取的值依靠的是当前表中属性表的数据或当前表中的图形对象,则该栏中所选择的表为当前表,否则需要设定的是要获取值的其他表,这涉及到表联接的内容,在后面的章节中会详细讲解。,“值”栏:如果需要更新列的值是固定值,则将该值填到值一栏即可,值的填写需要区分值的性质,比如常数可直接填写,文字需要用英文双引号把值的内容括起来;如果需要更新列的值是非固定值,则需要利用该栏后面的“辅助”命令进行表达式的创建。“浏览结果”项:根据需要来设定是否要在新建的浏览窗口中查看更新列的结果。,5)完成窗口设置,单击“确定”,结束“更新列”操作。,操作演示,例3.1为“地级城市驻地”属性表中的“省份”列赋地级城市点所属省份值,如图3-6,比如“滁州市”记录相应的“省份”列赋值“安徽省”。,操作步骤,1)打开地级城市驻地,修改表结构,增加【省份】字段。,操作步骤:,2)将某省(以安徽省为例)区域对象范围内的“地级城市驻地”点对象选中。点击主工具栏中的“边界选择”按钮,在激活该工具的情况下,单击安徽省区域对象,选中处于安徽省区域范围内的所有“地级城市驻地”点对象。,2)启动“更新列”,并对窗口进行设置,如图3-7,3)单击“确定”完成完成安徽省地级市赋值,如图3-8,应用以上步骤完成其他省(直辖市)赋值。,练习,1.按照上述例题的方法,为“地级城市驻地”属性表中的“省份”列赋地级城市点所属省份值。(全国所有的省份),思考,思考一下,本例中要处理的问题能否有更为快捷的解决方法。,例3.2计算“省级行政区”属性表中的“AREA”列赋值,即通过区域对象计算出各省(直辖市)的面积,并存放到”AREA”列,如图3-9,操作步骤,1)因为本次操作是针对表中所有记录的操作,所以无需选中对象。直接启动“更新列”,并对“更新列”窗口进行设置。其中“值”一栏设置方法为:点击“辅助”按钮,弹出“表达式”窗口,如图3-10。,单击“函数”项下拉菜单,选择“SphericalArea”函数项,如图3-11。,编辑“表达式”窗口中的函数表达式,如图3-12。在表达式SphericalArea(obj,sqkm)中的“obj”代表的是图形对象,“sqkm”代表的是面积单位平方千米,可以通过修改它来改变利用函数表达式计算的结果,如“sqmi”的计算结果单位为平方英里。,依据情况可点击“列”、“操作数”、“函数”项下拉菜单来编辑表达式,如果表达式熟练地用户可以在“更新列”窗口中的“值”一栏中直接输入表达式。单击确定完成“表达式”窗口的编辑。最后得到“更新列”窗口的设置结果如图3-13。,2)单击“确定”按钮得出为“AREA”列的编辑结果,如图3-14,在打开“表达式”窗口中的“函数”项下拉菜单时,我们会发现其中有三个计算面积的函数:Area、CartesianArea、SphericalArea。实际上,在大多数情况下,会应用CartesianArea、SphericalArea项来计算区域对象的面积。而CartesianArea函数主要应用于在坐标系统设定为NonEarth的情况下,其他的多应用SphericalArea函数。,2.在表中添加行,如果希望将记录从一个表添加到另一个表,也可称为将两个表的内容合并到一个表,可使用“表”菜单下的“在表中添加行”命令。但是,这两个表的列的排放顺序应该相同。,操作步骤:,1)在“表”菜单上,单击“在表中添加行”命令。此时将显示相应的对话框,如图3-15,2)指定包含所要添加的记录的表。3)指定要将记录添加到的表,然后单击确定。演示:从A表追加行到B表,如果两个表中相应的列不具有相同的数据类型,则系统会进行最佳匹配,将数据转换为适当类型。如果两个表的列的顺序不同,可使用“表结构”命令在使用“在表中添加行”命令之前对列重新排序。,注:如果表可绘制地图,则一个表中的地图边界必须足够大,以便源自另一个表中的对象可以置于其中。否则,相应对象将会变形,以适应地图窗口的边界。此时可使用“坐标系边界管理器”工具来更改表的地图边界。,3.表联接,实际上,本节内容也属于“更新列”的部分,不过表的联接在理解起来稍有难度,因此将他专门设置为一节来介绍。当在编辑某个表文件的属性表的过程中,对该属性表进行“更新列”操作,且该列的值获取来源于另外一个表文件,则需要应用表的联接功能。,下面通过一个例子来讲解表联接的应用方法。通过该方法解决在“更新列”一节中的例3.1中的问题,相对例3.1中的解决方法,本方法要简捷的多。步骤如下:,1)在不选中“地级城市驻地”表文件任何对象或任何记录的情况下,点击“表”菜单下的“更新列”命令,弹出“更新列”窗口,如图3-16。,2)设置“更新列”窗口在窗口中的“要更新的表”栏中设定“地级城市驻地”表图层,“要更新的列”栏设定为“省份”列。“从中获得值的表”栏设定为“省级行政区”表图层,当设定为该图层时,“更新列”窗口中的部分设置内容发生变化,如图3-17,点击“联接”按钮,弹出“指定联接”窗口,如图3-18。,在“指定联接”窗口中包含两个主要选择:一是通过两个属性表中关键字段进行链接,来获取值(要想深入理解通过关键字段进行表联接的含义,可阅读例3.3中的内容);二是通过两个表中图形对象的空间关系来进行表的联接。在“指定联接”窗口中涉及到的空间对象的空间关系主要包含三个方面:包含、包含于、相交,如图3-19,根据两个表文件中对象间的空间关系来确定选择哪一项,在本过程中选择“包含”。然后,单击“确定”按钮。返回到“更新列”窗口。然后对“计算”和“属于”两栏进行设置,结果如图3-20。,3)单击“确定”键,完成更新列操作。,练习,2)使用联接表的方式,用world表中countr列的值更新worldcap表中country列的值。数据:练习数据worldworld数据:练习数据worldworldcap,操作演示,例3.3应用属性表的联接通过表A为表B中的“所属区域”列赋值。,1)首先认识一下表A、B,表A存放的区域对象,其图形窗口和属性表如图3-21,表A中仅包含了两个区域对象。,表B存放的为点对象,其图形和属性表如图3-22,其中id列有值,“所属区域”列为空值,需要通过属性表的联接操作为其赋值。,通过图3-22可见,表B的属性表中的id列和表A中的id列有一种关系,即处于某区域对象范围内的点对象的id值与该区域对象的id值相同。由此,可以进一步得出,如果“表B的id值”等于“表A的id值”,则将表A中与id值相对应的name列的值赋给表B中“所属区域”列的相应记录。如,表B中id列的1值和表A中id列的1值对应,则将表A中与1值所属同一条记录的name列的值“甲-region”赋给表B中id列值为1的“所属区域”列。,2)点击“表”菜单的“更新列”命令,打开“更新列”窗口,如图3-23,并进行设置。,“要更新的表”栏中的表图层设定为“B”,“要更新的列”栏设定为“所属区域”,“从中获得值的表”栏设定为“A”,此时“更新列”窗口中的部分内容改变。单击“联接”按钮,弹出“指定联接”窗口,在窗口中的设定如图3-24所示。,单击“确定”键,返回“更新列”窗口。对窗口中的“计算”和“属于”栏进行设定,结果如图3-25所示。,3)单击“确定”按钮,完成“所属区域”列的更新,结果如图3-26所示。,练习,3)使用属性表联接的方式,用world表中country列的值更新worldcap表中country列的值。(使用两个表中的capital列进行匹配)数据:练习数据worldworld数据:练习数据worldworldcap,4.紧缩表,紧缩表用于压缩表,以占用较少的磁盘空间。在此可选只紧缩表格数据、只紧缩图形对象或两者都紧缩。紧缩表格数据将移除已删除的记录,如图3-27所示。,要紧缩表,请执行以下操作:在表菜单上,指向维护,然后单击紧缩表。此时将显示“紧缩表”对话框。选择适当的表,以及是要只紧缩表格数据、只紧缩地图数据还是或两者都紧缩。单击确定。,注:紧缩表可令保存到工作空间的自定义标注崩溃。如果要使用自定义标注,可在创建标注之前紧缩表。,练习,4)在worldcap表中增加两个字段Ctry_Pop,十进制(8,0);Pop_rate,字符型(25).使用更新列,用world表中Pop_1994列的值更新worldcap表中Ctry_Pop列的值。使用更新列,更新worldcap表中Pop_rate列的值。Pop_rate:首都人口数占本国人口数的百分比,用百分数的形式表示,如:20%、30%等,综合练习3:属性录入及分区人口数计算,按照综合练习3的要求,完成任务。,
展开阅读全文
相关资源
相关搜索

当前位置:首页 > 图纸专区 > 课件教案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!