在excel中如何实现在A1列输入名称,在b1列自动出现相应的数据

例在A1列输入A,B1中自动出现2
在A2列输入B,B2中自动出现1.1

一、这可以用INDIRECT函数来完成。

二、INDIRECT函数的定义:

返回由文本字符串指定的引用。此函数立即对引用进行计算,并显示其内容。当需要更改公式中单元格的引用,而不更改公式本身,请使用函数 INDIRECT。

语法

INDIRECT(ref_text,a1)

Ref_text    为对单元格的引用,此单元格可以包含 A1-样式的引用、R1C1-样式的引用、定义为引用的名称或对文本字符串单元格的引用。如果
ref_text 不是合法的单元格的引用,函数 INDIRECT 返回错误值 #REF!。

    如果 ref_text 是对另一个工作簿的引用(外部引用),则那个工作簿必须被打开。如果源工作簿没有打开,函数 INDIRECT 返回错误值
    #REF!。

A1    为一逻辑值,指明包含在单元格 ref_text 中的引用的类型。

    如果 a1 为 TRUE 或省略,ref_text 被解释为 A1-样式的引用。

    如果 a1 为 FALSE,ref_text 被解释为 R1C1-样式的引用。

三、举例

(1)假设在A1单元格中写入“B100”这样的数据,想在B1单元格得出B100单元格的内容(即A1单元格写入文本单元格地址,在B1单元格得出这个单元格的内容),则B1单元格写入公式:

=INDIRECT(A1)

(2)假设在A1单元格中写入数字50,想在B1单元格得出C50单元格的内容(即A1单元格写入行数,在B1单元格得出C列该行单元格的内容),则B1单元格写入公式:

=INDIRECT("C"&A1)

(3)假设在A1单元格中写入字母"H",想在B1单元格得出H20单元格的内容(即A1单元格写入列名,在B1单元格得出第20行该列单元格的内容),则B1单元格写入公式:

=INDIRECT(A1&20)

(4)假设在A1单元格中写入字母"G",在B1单元格写入数字40,想在C1单元格得出G40单元格的内容(即A1单元格写入列名,B1单元格写入行数,要得出列名和行数组成的单元格的内容),则C1单元格写入公式:

=INDIRECT(A1&B1)

 

四、单元格地址

表格的顶上是一排字母A,B,C,.......这个就是列标
表格的左边是一竖列的数字1,2,3,.......这个就是行号
列标加上行号就是就是单元格的名称,单元格名称也叫做单元格地址,如A列的第三行,为A3单元格,C列的第18行为C18单元格,第五列的第七行就是E7单元格,这样形成了一个个的坐标,标明了每个单元格的位置.

 

温馨提示:答案为网友推荐,仅供参考
第1个回答  2009-09-12

这个要用Vlookup来做了,先要 做 一张底表,也就是你想的选项所对应的结果的一张表,然后你再去看下注释就可以咯... 

照我的图片去做 一下也可以的!

加了IF函数,防止A1 或者B1 没有数值的时候报错....

本回答被提问者采纳
第2个回答  2009-09-12
需要你在A列输入值与B列显示值的对照表(如果对应的值太多,这种方法不适合),或者对应关系。
例:1.以你所描述的为例,当A列某一单元格输入为A时,同一行B列单元格显示“2”;输入B时,显示“1.1”,在B1单元格输入如下公式,然后复制/粘贴到B列所有单元格:
=if(A1="A",2,if(A1="B",1.1,""))
该公式的意思是:若A1单元格输入为A,则B1单元格的值为2,否则判断输入是否为B,若是,则其值为1.1,否则为空。若有更多的可能出现的值,依次用if函数嵌套。
2.若输入值与显示值有其它特定的对应关系,同样使用if函数,可通过运算得到B列的值,只是判断条件和值不同而已(判断条件和值都可以使用公式)。
第3个回答  2009-09-12
B1=(IF(A1="A",1,1.1))

我不知道你说的是不是只有a b这两个数据,也不知道你是不是就只有1和1.1这两个数据判定的,如果是的话就这么设置公式下列就行的,记得一点,B列要设置单元格中的数据的小数点要一位的
相似回答