S9S12G128运用内部晶振8MHZ,利用定时器定时1秒,实现呼吸灯

时间: 2023-09-15 20:17:32 浏览: 26
好的,针对您的问题,我可以给出以下方案: 1. 首先需要了解S9S12G128的内部晶振频率,一般为8MHz。 2. 接下来可以配置一个定时器,可以选择S9S12G128的TIM或PIT模块。在配置定时器时,需要设置一个合适的定时时间,比如1秒。 3. 在定时器中断函数中,可以实现呼吸灯的效果。具体实现方式如下: a. 定义一个变量brightness,用来表示当前灯的亮度值,初始值为0。 b. 在定时器中断函数中,每次将brightness的值加上一个步进值step,比如1。当brightness的值达到一定的阈值时,就将步进值改为负数,比如-1。 c. 在每次定时器中断函数中,将brightness的值映射到PWM占空比,然后设置PWM输出,即可实现呼吸灯的效果。 d. 在定时器中断函数中,可以根据需要控制呼吸灯的亮度变化速率和亮度范围。 4. 最后需要将定时器和PWM模块进行初始化,并启动定时器中断。这样就可以实现S9S12G128利用内部晶振8MHz,通过定时器和PWM模块实现每秒呼吸灯的效果了。 以下是一个简单的例程,可以帮助您实现S9S12G128利用内部晶振8MHz,通过定时器和PWM模块实现每秒呼吸灯的效果。 ```c #include <hidef.h> /* common defines and macros */ #include <mc9s12g128.h> /* derivative information */ #include <math.h> #define PWM_FREQ 20000 // PWM输出频率 #define PWM_PERIOD 400 // PWM周期,即计数器最大值 #define PWM_DUTY_CYCLE 0 // PWM占空比,即计数器初值 unsigned int brightness = 0; // 当前亮度值 unsigned char step = 1; // 步进值,控制亮度变化速率和方向 unsigned int timeCount = 0; // 定时器计数 void init_PWM(void) { PWMCLK = 0x00; // 选择时钟源为内部总线时钟 PWMPRCLK = 0x00; // 不分频 PWMSCLA = 0x00; // 不分频 PWMSCLB = 0x00; // 不分频 PWMCTL = 0x00; // 选择边沿对齐模式 PWMPER0 = PWM_PERIOD & 0xFF; // 设置计数器最大值的低8位 PWMPER1 = PWM_PERIOD >> 8; // 设置计数器最大值的高8位 PWMDTY0 = PWM_DUTY_CYCLE & 0xFF; // 设置计数器初值的低8位 PWMDTY1 = PWM_DUTY_CYCLE >> 8; // 设置计数器初值的高8位 PWME = 0x01; // 使能PWM0输出 } void init_timer(void) { TSCR1 = 0x80; // 使能定时器 TSCR2 = 0x00; // 不分频 TIOS = 0x00; // 选择输入捕获模式 TCTL4 = 0x02; // 捕获上升沿 TFLG1 = 0x01; // 清除捕获中断标志 TIE_C1I = 1; // 使能捕获中断 } void interrupt VectorNumber_Vtimch1 timer_isr(void) { timeCount++; // 定时器计数加1 TC1 += 250000; // 设置下一次捕获值,即下一次定时1秒 if (timeCount == 1) { // 1秒到达 timeCount = 0; // 定时器计数清零 brightness += step; // 更新亮度值 if (brightness >= PWM_PERIOD) { // 达到最大亮度 brightness = PWM_PERIOD; step = -1; // 反转步进值,向下调整亮度 } else if (brightness <= 0) { // 达到最小亮度 brightness = 0; step = 1; // 反转步进值,向上调整亮度 } PWMDTY0 = brightness & 0xFF; // 设置计数器初值的低8位,即PWM输出占空比 PWMDTY1 = brightness >> 8; // 设置计数器初值的高8位 } } void main(void) { init_PWM(); // 初始化PWM模块 init_timer(); // 初始化定时器 EnableInterrupts; // 使能全局中断 for (;;) {} // 无限循环 } ``` 这个例程中,我们使用了PWM模块和定时器模块,其中PWM模块用于控制LED灯的亮度,定时器模块用于控制亮度的变化速率和方向,每秒进行一次亮度变化。在定时器中断函数中,我们实现了对亮度值的控制,根据需要调整步进值和亮度范围,使得LED灯呼吸效果更加平滑和自然。 希望这个例程能够帮到您,如果还有其他问题,请随时提出。

相关推荐

s9keaz128amlh是一款微控制器芯片,它需要通过驱动来使其正常工作。然而,驱动程序一般并不直接提供在官方网站上下载,而是由具体的硬件厂商或第三方软件开发者提供。对于s9keaz128amlh这款芯片,我们可以通过访问芯片制造商的官方网站来寻找相关的驱动程序。 通常,驱动程序提供的功能包括与操作系统、硬件设备和软件应用程序之间进行通信,以确保设备能够正确运行并与其他设备正确交互。驱动程序提供了必要的接口和控制命令,使操作系统或应用程序能够识别和使用特定的硬件设备或组件。在我们的例子中,s9keaz128amlh的驱动程序将提供与主机计算机的连接、与其他外围设备的通信以及与其他软件的相互操作等功能。 为了找到s9keaz128amlh的驱动程序,我们可以首先访问芯片制造商提供的官方网站。在官方网站上,我们可以找到有关该芯片的详细技术规格和相关文件,以及软件开发工具和支持资源。在这些资源中,相应的驱动程序通常会以软件包的形式提供,我们可以根据操作系统的类型和版本选择合适的驱动程序进行下载和安装。 另外,我们还可以查看第三方软件开发社区或论坛,以寻找其他用户或开发者分享的s9keaz128amlh的驱动程序。这些社区或论坛通常是开发者交流和共享经验的平台,我们可以在其中找到其他人已经开发或分享的驱动程序,并从中获取所需的软件资源。 综上所述,s9keaz128amlh的驱动程序需要通过访问芯片制造商官方网站或相关的第三方软件开发社区来获取,以确保该芯片能够正常工作并与其他硬件设备和软件应用程序正确交互。
很可能是因为TIMER_PERIOD的数据类型不匹配而导致设置定时器计数值出错。在S9S12G128芯片中,定时器计数器的计数值是一个16位无符号整数,范围是0x0000~0xFFFF。因此,如果TIMER_PERIOD的数据类型不是16位无符号整数,就会导致设置定时器计数值出错。 要解决这个问题,可以将TIMER_PERIOD的数据类型改为16位无符号整数,即unsigned int或uint16_t。同时,为了避免数据类型不匹配的问题,可以将定时器计数值直接赋值给TC7H和TC7L寄存器,而不是使用TC7寄存器。具体代码如下: #define TIMER_PERIOD 8000 // 定时器计数值 void timer_init(void); interrupt VectorNumber_Vtimch7 void timer_isr(void); void main(void) { timer_init(); // 初始化定时器 EnableInterrupts; // 开启全局中断 for(;;) { // 主循环中可以执行其他操作 } } void timer_init(void) { TSCR1 = 0x80; // 启动定时器,使用内部总线时钟 TSCR2 = 0x00; // 设置定时器时钟分频系数为1,不使用输出比较功能 TIOS |= 0x80; // 设置定时器7为输出比较模式 TC7H = TIMER_PERIOD >> 8; // 设置定时器计数值的高8位 TC7L = TIMER_PERIOD & 0xFF; // 设置定时器计数值的低8位 TIE |= 0x80; // 开启定时器7的中断 } interrupt VectorNumber_Vtimch7 void timer_isr(void) { TFLG1 |= 0x80; // 清除定时器7中断标志位 // 在这里执行需要定时执行的操作 } 在上述代码中,首先将TIMER_PERIOD的数据类型改为了unsigned int,并将其值设为8000,即定时器计数值的1/1000。然后在timer_init()函数中,将定时器计数值的高8位和低8位分别赋值给TC7H和TC7L寄存器。最后开启定时器7的中断。 这样做可以避免数据类型不匹配的问题,同时也可以提高代码的可读性和可维护性。
蚂蚁S9是一种基于FPGA(现场可编程门阵列)的开发板。它使用了Xilinx Spartan-6系列FPGA芯片,并提供了丰富的硬件资源和接口,适用于各种FPGA开发和嵌入式系统设计。 要开始使用蚂蚁S9进行FPGA开发,首先,您需要准备一些基本的工具和资源。这包括: 1. Vivado软件:Vivado是Xilinx提供的一套开发工具,用于设计、验证和实现FPGA项目。您可以从Xilinx官方网站上下载并安装Vivado软件。 2. 开发板支持文件:您需要获得蚂蚁S9的开发板支持文件,这些文件包括FPGA芯片的约束文件、引脚映射和IP核等。您可以从蚂蚁S9官方网站或相关论坛获取这些支持文件。 3. 开发环境设置:在Vivado中,您需要设置正确的开发环境,包括选择正确的FPGA芯片型号、引脚映射和时钟设置等。这些设置通常在Vivado的项目设置或选项菜单中进行。 一旦您准备好了这些工具和资源,您可以按照以下步骤开始进行蚂蚁S9 FPGA开发: 1. 创建一个新的Vivado项目:打开Vivado软件,创建一个新的项目,并选择适当的FPGA芯片型号。 2. 添加约束文件:将蚂蚁S9的约束文件添加到您的项目中,这些约束文件描述了FPGA芯片的引脚映射、时序要求等。 3. 设计和验证:使用Vivado提供的设计工具,设计您的FPGA电路,并使用仿真工具验证您的设计的功能和正确性。 4. 实现和生成比特流:在验证通过后,使用Vivado的实现工具将您的设计转换为比特流文件,该文件将被烧录到蚂蚁S9的FPGA芯片中。 5. 烧录比特流:使用适当的烧录工具将生成的比特流文件烧录到蚂蚁S9开发板上的FPGA芯片中。 6. 软件开发:如果您需要与FPGA交互或编写驱动程序,您可以使用C或其他编程语言开发相应的软件,以与蚂蚁S9上的FPGA进行通信。 这些是进行蚂蚁S9 FPGA开发的基本步骤,具体的开发流程和细节可能因项目需求和应用而有所不同。您可以参考相关的Xilinx官方文档、论坛或教程来获取更详细的指导和帮助。
### 回答1: 下面是一个简单的实现这个功能的Python代码: python # 初始化计数器 s6 = s7 = s8 = s9 = s10 = 0 # 循环输入学生成绩,并统计人数 for i in range(10): score = int(input("请输入第{}位学生的成绩:".format(i+1))) if score == 100: s10 += 1 elif score >= 90: s9 += 1 elif score >= 80: s8 += 1 elif score >= 70: s7 += 1 elif score >= 60: s6 += 1 # 输出统计结果 print("60~69分的人数为:", s6) print("70~79分的人数为:", s7) print("80~89分的人数为:", s8) print("90~99分的人数为:", s9) print("100分的人数为:", s10) 运行程序后,会依次提示输入每个学生的成绩,输入完成后会输出各个分数段的人数统计结果。 ### 回答2: 可以使用数组和循环来编写程序,实现对10个学生的成绩进行统计。 首先声明一个长度为11的整型数组,用来存放成绩统计结果,数组下标代表分数段。 然后使用循环,循环10次,每次循环读取一个学生的成绩并将其存入数组对应的分数段中。 最后,将数组中的统计结果输出到对应的S6、S7、S8、S9及S10单元中。 以下是一个示例代码: python def count_scores(): scores = [0] * 11 # 初始化一个长度为11的数组,初始值全为0 for i in range(10): score = int(input("请输入第%d个学生的成绩:" % (i + 1))) scores[score // 10] += 1 # 根据学生的成绩将对应的数组元素加1 results = [] for i in range(6, 11): results.append("S%d: %d人" % (i, scores[i])) return results statistics = count_scores() for result in statistics: print(result) 运行上述代码,依次输入10个学生的成绩,程序会统计并将结果输出。其中,S6表示60~69分的人数,S7表示70~79分的人数,S8表示80~89分的人数,S9表示90~99分的人数,S10表示100分的人数。 ### 回答3: 首先,我们可以使用数组来存储学生的成绩,数组的长度为10,用来存储10个学生的成绩。 然后,我们使用循环来逐个获取学生的成绩并进行统计,循环的次数为10次。 在循环中,我们使用if语句来判断学生的成绩属于哪个分数段,并进行相应的统计。统计每个分数段的人数可以用一个整型变量来进行累加。 最后,将统计得到的人数分别存放到S6、S7、S8、S9及S10单元中,可以通过给数组的相应元素赋值的方式实现。 以下是一个可能的解决方案: python scores = [] # 存储学生的成绩的数组 # 输入学生的成绩 for i in range(10): score = int(input("请输入第{}个学生的成绩:".format(i+1))) scores.append(score) # 初始化分数段的人数 count_s6 = 0 # 60-69分的人数 count_s7 = 0 # 70-79分的人数 count_s8 = 0 # 80-89分的人数 count_s9 = 0 # 90-99分的人数 count_s10 = 0 # 100分的人数 # 统计分数段的人数 for score in scores: if score >= 60 and score <= 69: count_s6 += 1 elif score >= 70 and score <= 79: count_s7 += 1 elif score >= 80 and score <= 89: count_s8 += 1 elif score >= 90 and score <= 99: count_s9 += 1 elif score == 100: count_s10 += 1 # 存放统计结果到数组中 result = [0, 0, 0, 0, 0] result[0] = count_s6 result[1] = count_s7 result[2] = count_s8 result[3] = count_s9 result[4] = count_s10 print("60-69分的人数:{}".format(result[0])) print("70-79分的人数:{}".format(result[1])) print("80-89分的人数:{}".format(result[2])) print("90-99分的人数:{}".format(result[3])) print("100分的人数:{}".format(result[4])) 这样,我们就可以得到每个分数段的人数,并将结果存放到相应的单元中。
要在 S9 韩版刷 TWRP,您需要遵循以下步骤: 首先,您需要确定您的 S9 韩版手机的型号号码,因为不同的型号可能需要不同的刷机步骤和文件。请在设备设置中查找型号号码。 接下来,您需要下载适用于您型号的 TWRP 安装文件。您可以通过在搜索引擎中输入“S9 韩版 TWRP 刷机教程”来找到适用于您型号的 TWRP 文件以及详细的刷机教程。确保您下载的文件与您的设备兼容。 一旦您下载了 TWRP 文件,您需要将手机连接到电脑,并启用开发者选项和 USB 调试模式。您可以在设置菜单的[关于手机]部分找到开发者选项,并在其中启用 USB 调试。然后将手机连接到电脑上。 接下来,您需要安装适用于您设备型号的刷机工具,例如 Odin。您可以在搜索引擎中搜索“S9 韩版刷机工具”以找到适用于您设备的刷机工具并下载安装。 一旦您安装了刷机工具,您可以根据刷机教程的步骤进入下载模式,并使用刷机工具将 TWRP 安装文件刷入您的设备。 刷入成功后,您可以在设备的启动选项中选择“恢复模式”,然后您将进入 TWRP 引导界面。如此一来,您已经成功在 S9 韩版手机上刷入了 TWRP。 请注意,在刷机过程中存在风险,可能会导致设备损坏或数据丢失。因此,在进行刷机操作之前,请确保您已备份重要的数据,并仔细阅读和遵循刷机教程中的所有步骤和警告。 这些是一般的步骤指南,但具体的操作可能因设备型号、软件版本等因素而略有不同。因此,请在进行刷机之前仔细研究和查阅适用于您设备的刷机教程,以确保操作正确和安全。
以下是使用状态机实现的Verilog代码: verilog module forbidden_sequence_detector( input clk, input reset, input data, output reg detect ); enum {START, S0, S1, S2, S3, S4, S5, S6, S7, S8, S9, S10, S11, S12, S13, S14, S15, S16, S17, S18} state; initial begin state = START; detect = 0; end always @(posedge clk) begin if (reset) begin state = START; detect = 0; end else begin case(state) START: begin if (data == 0) state = S0; else if (data == 1) state = S1; else if (data == 2) state = S2; else if (data == 3) state = S3; else if (data == 4) state = S4; else if (data == 5) state = S5; else if (data == 8) state = S6; else state = START; end S0: begin if (data == 1) state = S1; else state = START; end S1: begin if (data == 8) state = S6; else if (data == 2) state = S2; else state = START; end S2: begin if (data == 3) state = S3; else state = START; end S3: begin if (data == 10) state = S7; else if (data == 4) state = S4; else state = START; end S4: begin if (data == 5) state = S5; else state = START; end S5: begin if (data == 12) state = S8; else if (data == 19) state = S15; else state = START; end S6: begin if (data == 16) state = S11; else state = START; end S7: begin if (data == 17) state = S12; else state = START; end S8: begin if (data == 18) state = S13; else state = START; end S11: begin if (data == 9) state = S9; else state = START; end S9: begin if (data == 2) state = S2; else state = START; end S12: begin if (data == 24) state = S16; else state = START; end S13: begin if (data == 11) state = S10; else state = START; end S10: begin if (data == 4) state = S4; else state = START; end S15: begin if (data == 26) state = S18; else state = START; end S16: begin if (data == 32) state = S17; else state = START; end S17: begin if (data == 25) state = S14; else state = START; end S18: begin detect = 1; state = START; end default: begin state = START; end endcase end end endmodule 该代码使用状态机实现,对于每个输入数据,根据当前状态进行状态转移。如果检测到数字序列,输出信号detect会被置为1。

最新推荐

【NetTopologySuite】到点的距离

本工程在objectarx2020下测试通过,如要在其他版本的sdk下使用,需要修改工程的引用文件 编译方法: 1、将解压后的文件夹放到objectarx2020 文件夹 内samples\dotNet 目录下,如G:\mywork\my-object-arx\samples\dotNet 2、用vs2019或vs2022打开,编译即可 3、编译后的dll位于 G:\mywork\my-object-arx\samples\x64\Debug

【波导仿真】基于matlab矢量有限元法分析均匀波导【含Matlab源码 3564期】.zip

CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、物理应用 仿真:导航、地震、电磁、电路、电能、机械、工业控制、水位控制、直流电机、平面电磁波、管道瞬变流、刚度计算 光学:光栅、杨氏双缝、单缝、多缝、圆孔、矩孔衍射、夫琅禾费、干涉、拉盖尔高斯、光束、光波、涡旋 定位问题:chan、taylor、RSSI、music、卡尔曼滤波UWB 气动学:弹道、气体扩散、龙格库弹道 运动学:倒立摆、泊车 天体学:卫星轨道、姿态 船舶:控制、运动 电磁学:电场分布、电偶极子

基于javaweb的仿照百度网盘的小型云盘系统

javaweb项目完整案例

分布式高并发.pdf

分布式高并发

基于多峰先验分布的深度生成模型的分布外检测

基于多峰先验分布的深度生成模型的似然估计的分布外检测鸭井亮、小林圭日本庆应义塾大学鹿井亮st@keio.jp,kei@math.keio.ac.jp摘要现代机器学习系统可能会表现出不期望的和不可预测的行为,以响应分布外的输入。因此,应用分布外检测来解决这个问题是安全AI的一个活跃子领域概率密度估计是一种流行的低维数据分布外检测方法。然而,对于高维数据,最近的工作报告称,深度生成模型可以将更高的可能性分配给分布外数据,而不是训练数据。我们提出了一种新的方法来检测分布外的输入,使用具有多峰先验分布的深度生成模型。我们的实验结果表明,我们在Fashion-MNIST上训练的模型成功地将较低的可能性分配给MNIST,并成功地用作分布外检测器。1介绍机器学习领域在包括计算机视觉和自然语言处理的各个领域中然而,现代机器学习系统即使对于分

阿里云服务器下载安装jq

根据提供的引用内容,没有找到与阿里云服务器下载安装jq相关的信息。不过,如果您想在阿里云服务器上安装jq,可以按照以下步骤进行操作: 1.使用wget命令下载jq二进制文件: ```shell wget https://github.com/stedolan/jq/releases/download/jq-1.6/jq-linux64 -O jq ``` 2.将下载的jq文件移动到/usr/local/bin目录下,并添加可执行权限: ```shell sudo mv jq /usr/local/bin/ sudo chmod +x /usr/local/bin/jq ``` 3.检查j

毕业论文java vue springboot mysql 4S店车辆管理系统.docx

包括摘要,背景意义,论文结构安排,开发技术介绍,需求分析,可行性分析,功能分析,业务流程分析,数据库设计,er图,数据字典,数据流图,详细设计,系统截图,测试,总结,致谢,参考文献。

"结构化语言约束下的安全强化学习框架"

使用结构化语言约束指导安全强化学习Bharat Prakash1,Nicholas Waytowich2,Ashwinkumar Ganesan1,Tim Oates1,TinooshMohsenin11马里兰大学,巴尔的摩县(UMBC),2美国陆军研究实验室,摘要强化学习(RL)已经在解决复杂的顺序决策任务中取得了成功,当一个定义良好的奖励函数可用时。对于在现实世界中行动的代理,这些奖励函数需要非常仔细地设计,以确保代理以安全的方式行动。当这些智能体需要与人类互动并在这种环境中执行任务时,尤其如此。然而,手工制作这样的奖励函数通常需要专门的专业知识,并且很难随着任务复杂性而扩展。这导致了强化学习中长期存在的问题,即奖励稀疏性,其中稀疏或不明确的奖励函数会减慢学习过程,并导致次优策略和不安全行为。 更糟糕的是,对于RL代理必须执行的每个任务,通常需要调整或重新指定奖励函数。另一�

mac redis 的安装

以下是在Mac上安装Redis的步骤: 1. 打开终端并输入以下命令以安装Homebrew: ```shell /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" ``` 2. 安装Redis: ```shell brew install redis ``` 3. 启动Redis服务: ```shell brew services start redis ``` 4. 验证Redis是否已成功安装并正在运行: ```shell redis-cli ping

计算机应用基础Excel题库--.doc

计算机应用根底Excel题库 一.填空 1.Excel工作表的行坐标范围是〔 〕。 2.对数据清单中的数据进行排序时,可按某一字段进行排序,也可按多个字段进行排序 ,在按多个字段进行排序时称为〔 〕。 3.对数据清单中的数据进行排序时,对每一个字段还可以指定〔 〕。 4.Excel97共提供了3类运算符,即算术运算符.〔 〕 和字符运算符。 5.在Excel中有3种地址引用,即相对地址引用.绝对地址引用和混合地址引用。在公式. 函数.区域的指定及单元格的指定中,最常用的一种地址引用是〔 〕。 6.在Excel 工作表中,在某单元格的编辑区输入"〔20〕〞,单元格内将显示( ) 7.在Excel中用来计算平均值的函数是( )。 8.Excel中单元格中的文字是( 〕对齐,数字是( )对齐。 9.Excel2021工作表中,日期型数据"2008年12月21日"的正确输入形式是( )。 10.Excel中,文件的扩展名是( )。 11.在Excel工作表的单元格E5中有公式"=E3+$E$2",将其复制到F5,那么F5单元格中的 公式为( )。 12.在Excel中,可按需拆分窗口,一张工作表最多拆分为 ( )个窗口。 13.Excel中,单元格的引用包括绝对引用和( ) 引用。 中,函数可以使用预先定义好的语法对数据进行计算,一个函数包括两个局部,〔 〕和( )。 15.在Excel中,每一张工作表中共有( )〔行〕×256〔列〕个单元格。 16.在Excel工作表的某单元格内输入数字字符串"3997",正确的输入方式是〔 〕。 17.在Excel工作薄中,sheet1工作表第6行第F列单元格应表示为( )。 18.在Excel工作表中,单元格区域C3:E4所包含的单元格个数是( )。 19.如果单元格F5中输入的是=$D5,将其复制到D6中去,那么D6中的内容是〔 〕。 Excel中,每一张工作表中共有65536〔行〕×〔 〕〔列〕个单元格。 21.在Excel工作表中,单元格区域D2:E4所包含的单元格个数是( )。 22.Excel在默认情况下,单元格中的文本靠( )对齐,数字靠( )对齐。 23.修改公式时,选择要修改的单元格后,按( )键将其删除,然后再输入正确的公式内容即可完成修改。 24.( )是Excel中预定义的公式。函数 25.数据的筛选有两种方式:( )和〔 〕。 26.在创立分类汇总之前,应先对要分类汇总的数据进行( )。 27.某一单元格中公式表示为$A2,这属于( )引用。 28.Excel中的精确调整单元格行高可以通过〔 〕中的"行〞命令来完成调整。 29.在Excel工作簿中,同时选择多个相邻的工作表,可以在按住( )键的同时,依次单击各个工作表的标签。 30.在Excel中有3种地址引用,即相对地址引用、绝对地址引用和混合地址引用。在公式 、函数、区域的指定及单元格的指定中,最常用的一种地址引用是〔 〕。 31.对数据清单中的数据进行排序时,可按某一字段进行排序,也可按多个字段进行排序 ,在按多个字段进行排序时称为〔 〕。多重排序 32.Excel工作表的行坐标范围是( 〕。1-65536 二.单项选择题 1.Excel工作表中,最多有〔〕列。B A.65536 B.256 C.254 D.128 2.在单元格中输入数字字符串100083〔邮政编码〕时,应输入〔〕。C A.100083 B."100083〞 C. 100083   D.'100083 3.把单元格指针移到AZ1000的最简单方法是〔〕。C A.拖动滚动条 B.按+〈AZ1000〉键 C.在名称框输入AZ1000,并按回车键 D.先用+〈 〉键移到AZ列,再用+〈 〉键移到1000行 4.用〔〕,使该单元格显示0.3。D A.6/20 C.="6/20〞 B. "6/20〞 D.="6/20〞 5.一个Excel工作簿文件在第一次存盘时不必键入扩展名,Excel自动以〔B〕作为其扩展 名。 A. .WK1 B. .XLS C. .XCL D. .DOC 6.在Excel中,使用公式输入数据,一般在公式前需要加〔〕A A.= B.单引号 C.$ D.任意符号 7.在公式中输入"=$C1+E$1〞是〔〕C A.相对引用 B.绝对引用 C.混合引用 D.任意引用 8.以下序列中,不能直接利用自动填充快速输入的是〔 〕B A.星期一.星期二.星期三 .…… B.第一类.第二类.第三类.…… C.甲.乙.丙.…… D.Mon.Tue.Wed.…… 9.工作表中K16单元格中为公式"=F6×$D$4〞,在第3行处插入一行,那么插入后K7单元 格中的公式为〔 〕A A.=F7*$D$5 B.=F7*$D$4 C