AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题

问题[ksh](unix)

Martin Hope
Aravind
Asked: 2025-03-13 18:41:05 +0800 CST

数据提交至数据库,无需显式提交

  • 6

COMMIT我有一个将数据插入/更新到 Oracle 表中的 Shell 脚本,我不明白的是脚本中没有明确的说明但数据已提交到数据库,这怎么可能呢?

我已经检查过 sqlplus 是否autocommit已关闭(通过连接到 sqlplus 并运行SHOW AUTOCOMMIT;)

#! /bin/ksh

function Exec_Sql 
  { 
    echo === Executing sql:
    echo === $sql_text
    print "$sql_text;" | sqlplus -s / 2>&1 | grep -iE 'ora|error|sp2'
    if [ ! $? -eq 0 ] #No error found
    then
      v_sqlerrm=""
      return 0 #No Errors
    else
      v_sqlerrm="Contact Support - Check Log File" 
      return 1 #Error Found 
    fi
  }


sql_text="UPDATE asr_test_tab SET f_ind = 'Y'"
if Exec_Sql; then
  echo "=== Update SQL OK "
else
  echo "=== Update SQL Failed "
fi

echo Complete: `date`
exit 0;
ksh
  • 1 个回答
  • 32 Views
Martin Hope
Jacques R
Asked: 2024-11-04 21:50:47 +0800 CST

未知文件名为 1

  • 6

我经常会无意间创建一个文件。git 不会在我的项目中跟踪它。它只是名为1,仅包含true

我应该检查什么才能知道是什么原因导致创建此文件?

ksh
  • 1 个回答
  • 223 Views
Martin Hope
lylklb
Asked: 2023-07-24 20:56:00 +0800 CST

为什么 ksh93 在 AIX 中不支持其内置 printf 的 %T 格式说明符?

  • 9

我们在许多 AIX 5.3/6.1 系统中使用 ksh93 测试了以下命令printf,但它们都失败并得到相同的结果。

这是为什么?

# 
# oslevel -s                               
6100-07-09-1341
# 
# 
# ksh93 -c 'echo ${.sh.version}'
Version M-12/28/93e
# 
# 
# ksh93 -c 'printf "%T\n" "now"'      
ksh93[1]: printf: T: unknown format specifier
# 
# 
ksh
  • 2 个回答
  • 387 Views
Martin Hope
Lee
Asked: 2023-05-19 20:16:47 +0800 CST

ksh 参数扩展:将 / 替换为 -

  • 6

说我有这个:

str="@test/string"
echo $str
@test/string
echo ${str#@}
test/string

按预期工作,但是

echo ${str//\//-}
ksh: ${str//\//-}: bad substitution

失败。(预期@test-string)

替换/替换这样的字符的正确方法是什么?


echo $KSH_VERSION
KSH version @(#)PD KSH v5.2.14 99/07/13.2
ksh
  • 3 个回答
  • 37 Views
Martin Hope
Pat
Asked: 2022-09-13 03:37:57 +0800 CST

根据 file 命令将文件转换为 utf-8

  • 5

有一个上传过程,读取文件并使用 sqlldr 将数据上传到数据库。在 sqlldr 中处理文件时,我遇到了无效号码问题。发现文件是 UTF-16 格式,然后在 notepad++ 中转换为 UTF-8 格式,它开始工作正常。现在我正在尝试像下面这样系统地转换它。

iconv -f UTF-16 -t UTF-8 file_name >output_file_name

该文件可能具有不同的编码,因此我想在转换之前找到该文件的编码,然后根据该编码进行转换。类似于使用文件命令仅从下面读取 UTF-16,然后在 -f 选项中使用它。

bash-4.2$ file "/FILE_UPLOADS/Relationship (4).txt"
/FILE_UPLOADS/Relationship (4).txt: Little-endian UTF-16 Unicode text, with CRLF line terminators

我怎么做?

ksh
  • 3 个回答
  • 313 Views
Martin Hope
Dirk Horsten
Asked: 2022-06-03 08:00:11 +0800 CST

从 shell 脚本调用命令,传递大多数参数,允许带空格的参数

  • 1

我有一个批量运行 SAS 代码run_sas.sh的命令的包装器。sas典型的调用如下所示

./run_sas.sh -sysin /my_code/my_program.sas -log /my_log_folder/my_program.log
  • run_sas.sh将所有参数传递给saswith ./sas $*。
  • sas然后运行/my_code/my_program.sas并将日志写入/my_log_folder/my_program.log.
  • 然后run_sas.sh分析它被调用的参数
  • 并将日志复制到/admin/.hidden_log_folder/my_program_<today's date>.log

我想做两个改变:

启用多字参数

有些客户绝对希望我在文件夹和文件名中使用空格并要求我运行/their code/their program.sas,所以如果我运行

./run_sas.sh -sysin "/their code/their program.sas" -log "/their log folder"

/their code/their program.sas并且/their log folder应该将单个参数传递给sas

删除特定参数

有时我需要运行./sas_utf8而不是./sas我懒得维护第二个脚本,所以我想允许一个额外的参数,这样

./run_sas.sh -sysin /my_code/my_program.sas -log /my_log_folder -encoding utf8

会打电话

./sas_utf8 -sysin /my_code/my_program.sas -log /my_log_folder

代替

./sas -sysin /my_code/my_program.sas -log /my_log_folder

我该怎么做,最好是在ksh?

ksh array
  • 1 个回答
  • 252 Views
Martin Hope
Mineralwasser
Asked: 2022-01-20 05:06:35 +0800 CST

AIX 上的 ksh - 更改文件夹时提示中的 pwd 不更新

  • 0

我对 AIX 和 ksh 都很陌生,但我目前在工作中有一些停机时间,并且正在尝试将我的提示配置为彩色并显示我当前的位置。

目前,我在登录时只获得了一次正确的路径,之后它继续显示我的用户目录。颜色工作正常。日志名和主机名是正确的。

PS1="$(echo "\033[35m`logname`\033[34m@\033[35m`hostname` \033[36m`pwd`\033[1;35m\n\>\033[0m") "

无法显示屏幕截图,但示例输出在任何目录中都会如下所示:

userid@hostname /home/look/a/subfolder
>

我尝试了一堆不同的版本,但要么无法显示任何内容,要么所有特殊字符都以 .profile 的形式出现。

任何想法我做错了什么?

编辑:感谢 Stéphane,ESC+CTRL+V 有效,它是 ksh88。AIX 7.1

aix ksh
  • 2 个回答
  • 129 Views
Martin Hope
Pat
Asked: 2021-11-18 06:49:52 +0800 CST

根据分隔符读取第一行拆分并将其存储在数组中(在 ksh 中)

  • 0

我正在读取文件的第一行,标题行,按分隔符拆分|并将其分配给数组。

IFS='|' read -r -a header < "/file_uploads/file_headers.txt"

这在较低的环境中运行良好,但在较高的环境中它会给出错误,例如

file_upload_process.sh[47]: read: -a: unknown option
Usage: read [-ACprsSv] [-d delim] [-u fd] [-t timeout] [-n count] [-N count]
            [var?prompt] [var ...]
file_upload_process.sh[48]: read: -a: unknown option
Usage: read [-ACprsSv] [-d delim] [-u fd] [-t timeout] [-n count] [-N count]
            [var?prompt] [var ...]

看起来在较低和较高的环境中存在版本差异并导致此问题?有没有其他方法可以将文件的第一行读入带有分隔符拆分的数组?

text-processing ksh
  • 1 个回答
  • 153 Views
Martin Hope
Pat
Asked: 2021-10-30 06:57:29 +0800 CST

bash替换变量中的特殊字符

  • 4

管道 (|) 有限的文本文件从 Windows 应用程序传输以进行处理。处理时,文件第一行的第一列中有一个特殊字符。这是从 Windows 传输之前文件在记事本中的外观

Sector|Name|Manager|...

当我阅读IFS='|' read -r -a fields < "/uploads/file_data.txt"时,第一列扇区被读取为"Sector"带有前缀的特殊字符。

当我这样做时head -1 "/uploads/file_data.txt" | od -c,打印的值是

0000000 357 273 277   S   e   c   t   o   r   |

我试过tr -d < //uploads/file_data.txt > /uploads/file_data_temp.txt但没有帮助。如果将来上传的文件中有任何未知字符,我如何替换特殊字符不仅如此。

bash ksh
  • 1 个回答
  • 276 Views
Martin Hope
defekas17
Asked: 2021-10-29 07:47:38 +0800 CST

如何将查询多个结果存储在 shell 脚本变量(数组)中?

  • 2

我正在尝试进行查询并将每一行结果存储在 ksh 中的数组元素中(也许是 bash)。我愿意:

result=($($PATH_UTI/querysh "
set heading off
set feedback off
SELECT columnA,columnb FROM user.comunication;"))

我有这个:

row1 = HOUSE CAR
row2 = DOC   CAT
echo "${result[1]}" and it gives me HOUSE

但我想得到:

echo "${result[1]}" gives: "HOUSE CAR"
bash ksh
  • 2 个回答
  • 678 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve