我正在尝试将数据库中的一些值添加到[]stringGo中.其中一些是时间戳.
我收到错误:
不能使用U.Created_date(类型time.Time)作为数组元素中的类型字符串
我可以转换time.Time成string?
type UsersSession struct {
Userid int
Timestamp time.Time
Created_date time.Time
}
type Users struct {
Name string
Email string
Country string
Created_date time.Time
Id int
Hash string
IP string
}
Run Code Online (Sandbox Code Playgroud)
-
var usersArray = [][]string{}
rows, err := db.Query("SELECT u.id, u.hash, u.name, u.email, u.country, u.IP, u.created_date, us.timestamp, us.created_date FROM usersSession AS us LEFT JOIN users AS u ON u.id = us.userid WHERE us.timestamp + interval 30 minute >= now()")
U := Users{}
US := UsersSession{}
for rows.Next() {
err = rows.Scan(&U.Id, &U.Hash, &U.Name, &U.Email, &U.Country, &U.IP, &U.Created_date, &US.Timestamp, &US.Created_date)
checkErr(err)
userid_string := strconv.Itoa(U.Id)
user := []string{userid_string, U.Hash, U.Name, U.Email, U.Country, U.IP, U.Created_date, US.Timestamp, US.Created_date}
// -------------
// ^ this is where the error occurs
// cannot use U.Created_date (type time.Time) as type string in array element (for US.Created_date and US.Timestamp aswell)
// -------------
usersArray = append(usersArray, user)
log.Print("usersArray: ", usersArray)
}
Run Code Online (Sandbox Code Playgroud)
编辑
我添加了以下内容.它现在有效,谢谢.
userCreatedDate := U.Created_date.Format("2006-01-02 15:04:05")
userSessionCreatedDate := US.Created_date.Format("2006-01-02 15:04:05")
userSessionTimestamp := US.Timestamp.Format("2006-01-02 15:04:05")
Run Code Online (Sandbox Code Playgroud)
icz*_*cza 127
您可以使用该Time.String()方法将a转换time.Time为a string.这使用格式字符串"2006-01-02 15:04:05.999999999 -0700 MST".
如果您需要其他自定义格式,则可以使用Time.Format().例如,以yyyy-MM-dd HH:mm:ss使用格式字符串的格式获取时间戳"2006-01-02 15:04:05".
例:
t := time.Now()
fmt.Println(t.String())
fmt.Println(t.Format("2006-01-02 15:04:05"))
Run Code Online (Sandbox Code Playgroud)
输出(在Go Playground上试试):
2009-11-10 23:00:00 +0000 UTC
2009-11-10 23:00:00
Run Code Online (Sandbox Code Playgroud)
注意:Go Playground上的时间始终设置为上面显示的值.在本地运行以查看当前日期/时间.
另请注意,使用Time.Format(),作为布局,string您始终必须传递相同的时间 - 称为参考时间 - 格式化您希望格式化结果的方式.这记录在Time.Format():
格式返回根据布局格式化的时间值的文本表示,其通过显示定义的参考时间来定义格式
Run Code Online (Sandbox Code Playgroud)Mon Jan 2 15:04:05 -0700 MST 2006如果它是值,将显示; 它作为所需输出的一个例子.然后将相同的显示规则应用于时间值.
Hao*_*Hao 16
package main
import (
"fmt"
"time"
)
// @link https://golang.org/pkg/time/
func main() {
//caution : format string is `2006-01-02 15:04:05.000000000`
current := time.Now()
fmt.Println("origin : ", current.String())
// origin : 2016-09-02 15:53:07.159994437 +0800 CST
fmt.Println("mm-dd-yyyy : ", current.Format("01-02-2006"))
// mm-dd-yyyy : 09-02-2016
fmt.Println("yyyy-mm-dd : ", current.Format("2006-01-02"))
// yyyy-mm-dd : 2016-09-02
// separated by .
fmt.Println("yyyy.mm.dd : ", current.Format("2006.01.02"))
// yyyy.mm.dd : 2016.09.02
fmt.Println("yyyy-mm-dd HH:mm:ss : ", current.Format("2006-01-02 15:04:05"))
// yyyy-mm-dd HH:mm:ss : 2016-09-02 15:53:07
// StampMicro
fmt.Println("yyyy-mm-dd HH:mm:ss: ", current.Format("2006-01-02 15:04:05.000000"))
// yyyy-mm-dd HH:mm:ss: 2016-09-02 15:53:07.159994
//StampNano
fmt.Println("yyyy-mm-dd HH:mm:ss: ", current.Format("2006-01-02 15:04:05.000000000"))
// yyyy-mm-dd HH:mm:ss: 2016-09-02 15:53:07.159994437
}
Run Code Online (Sandbox Code Playgroud)
Son*_*rma 10
package main
import (
"fmt"
"time"
)
func main() {
v , _ := time.Now().UTC().MarshalText()
fmt.Println(string(v))
}
Run Code Online (Sandbox Code Playgroud)
输出 :2009-11-10T23:00:00Z
| 归档时间: |
|
| 查看次数: |
138591 次 |
| 最近记录: |