亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何為 fmt.sprintf 拆分長行

如何為 fmt.sprintf 拆分長行

Go
慕村225694 2021-12-07 17:15:22
我在 fmt.Sprintf 中有很長的一行。我如何在代碼中拆分它?我不想將所有內容都放在一行中,因此代碼看起來很難看。fmt.Sprintf("a:%s, b:%s  ...... this goes really long")
查看完整描述

3 回答

?
滄海一幻覺

TA貢獻1824條經驗 獲得超5個贊

使用字符串連接在多行上構造單個字符串值:


 fmt.Sprintf("a:%s, b:%s " +

    " ...... this goes really long",

    s1, s2)

本示例中的長字符串是在編譯時構建的,因為字符串連接是一個常量表達式。


您可以使用原始字符串文字在包含的換行符處拆分字符串:


     fmt.Sprintf(`this text is on the first line

and this text is on the second line,

and third`)


查看完整回答
反對 回復 2021-12-07
?
白衣非少年

TA貢獻1155條經驗 獲得超0個贊

您還可以在反引號內使用原始字符串文字,如下所示:


columns := "id, name"

table := "users"

query := fmt.Sprintf(`

    SELECT %s

    FROM %s

  `, columns, table)

fmt.Println(query)

這種方法有一些注意事項:


原始字符串不解析轉義序列

所有空格都將被保留,因此FROM在此查詢中的子句之前會有一個換行符和幾個制表符。

這些問題對某些人來說可能是一個挑戰,空格會產生一些難看的結果字符串。但是,我更喜歡這種方法,因為它允許您將長而復雜的 SQL 查詢復制并粘貼到代碼之外并粘貼到其他上下文中,例如用于測試的 sql 工作表。


查看完整回答
反對 回復 2021-12-07
?
www說

TA貢獻1775條經驗 獲得超8個贊

您還可以在反引號內使用原始字符串文字,如下所示:


columns := "id, name"

table := "users"

query := fmt.Sprintf(`

    SELECT %s

    FROM %s

  `, columns, table)

fmt.Println(query)

這種方法有一些注意事項:


原始字符串不解析轉義序列

所有空格都將被保留,因此FROM在此查詢中的子句之前會有一個換行符和幾個制表符。

這些問題對某些人來說可能是一個挑戰,空格會產生一些難看的結果字符串。但是,我更喜歡這種方法,因為它允許您將長而復雜的 SQL 查詢復制并粘貼到代碼之外并粘貼到其他上下文中,例如用于測試的 sql 工作表。


查看完整回答
反對 回復 2021-12-07
  • 3 回答
  • 0 關注
  • 558 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號