当前位置: 首页 > news >正文

将Excel中的数据导入shell脚本,并调用expect脚本

主脚本test.sh

#!/bin/bash
# 设置超时时间
set timeout 240
# 将 Excel 文件转换为 CSV 格式
# test.xlsx > temp.csv
# 初始化一个二维数组
declare -A data
# 逐行读取 CSV 文件,并将每个单元格的数据存储在二维数组中
row=1
while IFS=, read -r col1 col2 col3 col4 col5 col6 col7; dodata[$row,1]=$col1data[$row,2]=$col2data[$row,3]=$col3data[$row,4]=$col4data[$row,5]=$col5data[$row,6]=$col6data[$row,7]=$col7((row++))
done < test.csv
echo $row
# 打印二维数组的内容(仅作示例,您可以根据需要进行其他操作)
index=2
echo $index
num=$row-1
echo $num
while(($index<=$num))
doecho "Row $index: ${data[$index,1]}, ${data[$index,2]}, ${data[$index,3]}, ${data[$index,4]}, ${data[$index,5]}, ${data[$index,6]}, ${data[$index,7]}"# 运行希望自动化的脚本并等待特定提示expect child.sh ${data[$index,1]} ${data[$index,2]} ${data[$index,3]} ${data[$index,4]} ${data[$index,5]} ${data[$index,6]} ${data[$index,7]}((index++))
done

子脚本

#!/usr/bin/expect -f
#!/bin/bash
# 输出参数的数量
puts "Number of arguments: $argc"# 输出所有的参数
puts "Arguments: $argv"# 输出单独的参数
puts "First argument: [lindex $argv 0]"
puts "Second argument: [lindex $argv 1]"
puts "Third argument: [lindex $argv 2]"
set myhost [lindex $argv 1]
set myport [lindex $argv 2]
set myuser [lindex $argv 3]
set mypassword [lindex $argv 4]
set myproname [lindex $argv 5]
spawn ./ProjectCreator.out
expect {
"Please choose the database type(请输入数据库类型0-PostgreSQL/1-MySQL):" { send "[lindex $argv 0]\r"; exp_continue}
"Please input IP of the database(请输入数据库IP):" { send "[lindex $argv 1]\r"; exp_continue}
"Please input port of the database(请输入数据库端口):" { send "[lindex $argv 2]\r"; exp_continue }
"Please input username of the database(请输入数据库用户名):" { send "[lindex $argv 3]\r"; exp_continue}
"Please input the password of the database(请输入数据库密码):" { send "[lindex $argv 4]\r"; exp_continue}
"Please input the project name(请输入项目名称):" { send "[lindex $argv 5]\r"; exp_continue}
"Please choose the project language(请选择语言类型0-中文/1-English):" { send "[lindex $argv 6]\r"; exp_continue}}
#继续留在命令行执行过程
interact
sleep 180
http://www.lryc.cn/news/251102.html

相关文章:

  • elementui el-table用span-method方法对相同的列名或行名进行合并
  • 汇编语言实现音乐播放器
  • 大型网站系统架构演化(Web)
  • 三轴加速度计LIS2DW12开发(2)----基于中断信号获取加速度数据
  • Shell循环:whileuntil
  • Redis 安装部署
  • 项目中遇到的半导体公司
  • 汇编:call与ret/retf指令
  • Fiddler抓包工具之高级工具栏中的重定向AutoResponder的用法
  • 如何基于OpenCV和Sklearn库开展数据降维
  • 详解SpringAop开发过程中的坑
  • 【海思SS528 | VDEC】MPP媒体处理软件V5.0 | VDEC的使用总结
  • Kubernetes sample-controller 例子介绍
  • 【C/C++指针】指针*与引用的区别
  • 【ArcGIS Pro微课1000例】0039:制作全球任意经纬网的两种方式
  • 【二叉树】练习题终章
  • flutter开发实战-实现获取视频的缩略图封面video_thumbnail
  • Prompt Toolkit探索:打造交互式CLI应用
  • 【已解决】AttributeError: module ‘gradio‘ has no attribute ‘outputs‘
  • WPF Mvvm模式下面如何将事件映射到ViewModel层
  • C# WPF上位机开发(计算器界面设计)
  • [c]比较月亮大小
  • 【Java 基础】16 泛型
  • Android framework定制1-->用户无操作一段时间,自动播放客户提供的视频,用户操作后退出播放
  • Vmware17虚拟机安装windows10系统
  • Golang实践录:读取yaml配置文件
  • oracle sql相关语法
  • el-table,列表合并,根据名称列名称相同的品名将其它列值相同的进行合并
  • 微信小程序显示二维码?
  • JavaWeb开发全流程笔记