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

将Excel中的数据导入shell脚本

#!/usr/bin/expect -f
#!/bin/bash

# 设置超时时间
set timeout 240
# 将 Excel 文件转换为 CSV 格式
xlsx2csv test.xlsx > temp.csv

# 初始化一个二维数组
declare -A data

# 逐行读取 CSV 文件,并将每个单元格的数据存储在二维数组中
row=1
while IFS=, read -r col1 col2 col3 col4 col5; do
    data[$row,1]=$col1
    data[$row,2]=$col2
    data[$row,3]=$col3
    data[$row,4]=$col4
    data[$row,5]=$col5
    ((row++))
done < temp.csv
echo $row
# 打印二维数组的内容(仅作示例,您可以根据需要进行其他操作)
#for row in "${!data[@]}"; 
#do
    #echo "Row $row: ${data[$row,1]}, ${data[$row,2]}, ${data[$row,3]}, #${data[$row,4]}, ${data[$row,5]}"
#done
index=2
echo $index
num=$row-1
echo $num
while(($index<=$num))
do
    echo ${data[$index,4]}
    let "index++"
    # 运行希望自动化的脚本并等待特定提示
    spawn ./ProjectCreator.out
    expect {
    "Please input IP of the database(请输入数据库IP):" { send "${data[$index,1]}\r"; exp_continue}
    "Please input port of the database(请输入数据库端口):" { send "${data[$index,2]}\r"; exp_continue }
    "Please input username of the database(请输入数据库用户名):" { send "${data[$index,3]}\r"; exp_continue}
    "Please input the password of the database(请输入数据库密码):" { send "${data[$index,4]}\r"; exp_continue}
    "Please input the project name(请输入项目名称):" { send "${data[$index,5]}\r"; exp_continue}}
    #继续留在命令行执行过程
    interact
    sleep 180
    psql "host=192.168.0.100 port=5432 user=postgres  password=postgres dbname=postgres" <<-EOF #> /home/cet/temp/DataCacheUpdateTest/database/$today/$filename.txt
	SELECT pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity WHERE datname="PECSTAR_CONFIG_${data[$index,5]}" AND pid<>pg_backend_pid();
	drop database "PECSTAR_CONFIG_${data[$index,5]}";
	EOF
done


#echo ${data[1,1]}
# 删除临时 CSV 文件
rm temp.csv

http://www.kler.cn/news/136004.html

相关文章:

  • 用java编写图书管理系统
  • HDCTF2023 - Reverse方向全WP
  • 在Oracle 11g 数据库上设置透明数据加密(TDE)
  • 【SpringCloud】Eureka基于Ribbon负载均衡的调用链路流程分析
  • BLIP-2:冻结现有视觉模型和大语言模型的预训练模型
  • C#具名参数(Named Parameters)
  • Ubuntu下发送邮件
  • C#编程题分享(1)
  • 【亚马逊云科技产品测评】活动征文|aws云服务器 + 微服务Spring Cloud Nacos 实战
  • 使用Java解决快手滑块验证码
  • unity 打包exe设置分辨率
  • 线上bug-接口速度慢
  • Spring Boot - 自定义注解来记录访问路径以及访问信息,并将记录存储到MySQL
  • 解决 Python requests 库中 SSL 错误转换为 Timeouts 问题
  • 使用 Core Tools 在本地开发 Azure Functions
  • 【图数据库实战】-HugeGraph系列
  • SpringCloud 微服务全栈体系(十四)
  • 【brpc学习案例实践一】rpc服务构造基本流程
  • 彻底解决electron-builder安装问题与npm下载配置问题
  • Docker发布简单springboot项目
  • C++ 删除无头链上所有指定值为x的节点。
  • Redis设计与实现-数据结构(建设进度15%)
  • Re50:读论文 Large Language Models Struggle to Learn Long-Tail Knowledge
  • ubuntu 查看5000端口是否开放
  • 2023 极术通讯-汽车“新四化”路上,需要一片安全山海
  • 享元模式学习
  • 艾泊宇产品战略:灵感于鬼屋,掌握打造卓越用户体验的关键要素
  • C#单例模式懒汉式与饿汉式
  • CentOS 8搭建WordPress
  • 原理Redis-ZipList