การกด Enter จะสร้าง ^ M แทนการขึ้นบรรทัดใหม่


94

ตัวอย่างเช่นหากฉันกำลังtail -fใช้ไฟล์หรือกำลังreadป้อนข้อมูลผู้ใช้<Enter>จะสร้าง^Mในเทอร์มินัลแทนการสิ้นสุดreadหรือเพิ่มบรรทัดใหม่ให้ stdout ^Jทำงานได้ดี

ฉันกำลังsshเข้าสู่ระบบอูบุนตูถ้าเป็นเช่นนั้น สิ่งนี้เกิดขึ้นกับฉันทั้งใน zsh และ bash ทางออกหนึ่งที่ฉันเล่นด้วยคือทำการแมป^Mไปยัง^Jin zsh แต่ดูเหมือนว่าจะไม่สามารถแก้ไขปัญหารากได้ ใครรู้ว่าอาจเป็นสาเหตุของเรื่องนี้

แก้ไข: เพื่อตอบคำถามบางอย่างฉันกำลังsshเข้า Ubuntu จาก OSX ฉันใช้ iTerm และ zsh ฉันลืมที่จะพูดถึงว่าฉันใช้ tmux บนเครื่อง Ubuntu

แก้ไข 2: พลาดคำถาม เมื่อฉันพิมพ์Ctrl-V Enterฉันจะได้รับ^M(ทั้งบน OSX และ Ubuntu)

แก้ไขที่ 3: ใน OSX และ Ubuntu ผลิตecho $TERMscreen-256color


คุณใช้ ssh กับ Ubuntu ทำอะไร
Tasos

ใช่ --- และระบบปฏิบัติการใด? ดูเหมือนปัญหาระยะเวลา
Rmano

คุณได้อะไรถ้าคุณพิมพ์Ctrl + Vตามด้วยใส่ ? เนื่องจากคุณสามารถรันคำสั่งได้ดีนี่ไม่ใช่ปัญหาของเชลล์
Adaephon

2
การรีสตาร์ทกล่อง OSX ของฉันโดยไม่สมัครใจดูเหมือนว่าจะแก้ไขปัญหาได้แล้ว ... ฉันคิดว่ามันเป็นหนึ่งในนั้น หวังว่ามันจะหายดี
benekastah

สำหรับฉันสิ่งเดียวที่ใช้ได้คือการรีสตาร์ทรวมถึงการกวาดล้าง NVRAM กดปุ่ม Command-Option-PR ค้างไว้ทันทีหลังจากที่คุณได้ยินเสียงเริ่มต้นเพื่อรีเซ็ต NVRAM ของ
OSx ด้วย

คำตอบ:


192

ในกรณีที่คนอื่นมีปัญหานี้เป็นไปได้มากที่สุดว่ามีปัญหากับการตั้งค่าบรรทัด stty เทอร์มินัลมากกว่าปัญหา TERM หากสิ่งนี้เกิดขึ้นกับคุณอีกครั้งให้ลองเรียกใช้stty saneและแจ้งให้เราทราบว่าวิธีแก้ไขนั้น


22
ใช้งานได้กับ OS X เช่นกัน
Patrick Berkeley

1
ทำงานให้ฉัน (มินต์ 17.1)
Deleet

1
ทำงานบน Ubuntu Bionic
protoEvangelion

ทำงานได้ดีบน iTerm2 บน Mojave
Rakib

ทำงานกับลูกแมวของฉันที่ archlinux
yukashima huksay

31

ลองเรียกใช้stty -aเพื่อดูการตั้งค่าเครื่องของคุณ ความสงสัยของฉันคือicrnlการตั้งค่าของคุณไม่ได้ตั้งค่าไว้และจะแสดงเป็น-icrnl(เครื่องหมายลบหมายถึงปิดอยู่) แทนที่จะตั้งค่าตามปกติ นี่คือวิธีตั้งค่าเทอร์มินัลของฉันตามปกติเมื่อฉันเข้าสู่ระบบ:

$ stty -a
speed 38400 baud; rows 45; columns 80; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;
eol2 = <undef>; swtch = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R;
werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;
-parenb -parodd cs8 -hupcl -cstopb cread -clocal -crtscts
-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr icrnl -ixon -ixoff
-iuclc -ixany -imaxbel iutf8
opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0 bs0 vt0 ff0
isig icanon iexten echo echoe echok -echonl -noflsh -xcase -tostop -echoprt
echoctl echoke

และฉันไม่มีปัญหากับการจบบรรทัด: return (^ M) หรือ enter (^ J) จะสิ้นสุดบรรทัดอินพุต แต่ถ้าฉันicrnlปิดแล้ว ^ M รหัสปรากฏขึ้นทุกครั้งที่ฉันพูดคุยกับโปรแกรมและกด Enter:

$ stty -icrnl
$ read line
Line of text^M^M^M^M
$ stty -a
speed 38400 baud; rows 45; columns 80; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;
eol2 = <undef>; swtch = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R;
werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;
-parenb -parodd cs8 -hupcl -cstopb cread -clocal -crtscts
-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr -icrnl -ixon -ixoff
-iuclc -ixany -imaxbel iutf8
opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0 bs0 vt0 ff0
isig icanon iexten echo echoe echok -echonl -noflsh -xcase -tostop -echoprt
echoctl echoke

รหัสicrnlหมายถึง“ เปลี่ยนการขึ้นบรรทัดใหม่เป็นบรรทัดใหม่” และซ่อนจากโปรแกรมที่กำลังทำงานอยู่ซึ่งคุณอาจพิมพ์ ^ M เมื่อ Unix ต้องการ ^ J จริงๆ แป้นพิมพ์เก่าที่เคยมีคีย์ Return และ Enter แยกต่างหาก (โดยทั่วไปแล้ว Return จะส่งคุณผ่านฟอร์มและ Enter ที่ส่ง) แต่วันนี้เรามักจะมีคีย์สิ้นสุดบรรทัดเดียวเท่านั้นดังนั้นการตั้งค่าเทอร์มินัลนี้จะช่วยรวมสองความหมาย

เพิ่มstty icrnlคำสั่งของคุณ.profileหรือ.bashrcถ้าคุณพบว่านี่เป็นการตั้งค่าปัญหา

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.