到目前为止,我有以下代码片段:
Sql2o sql2o = new Sql2o("jdbc:sqlite:test.db");
try (Connection connection = sql2o.open()) {
for (Column column : connection.createQuery("SELECT * FROM sometable").executeAndFetchTable().columns())
System.out.println(column.toString());
}
Run Code Online (Sandbox Code Playgroud)
我正在使用这些依赖项:
<dependency>
<groupId>org.sql2o</groupId>
<artifactId>sql2o</artifactId>
<version>1.5.4</version>
</dependency>
<dependency>
<groupId>org.xerial</groupId>
<artifactId>sqlite-jdbc</artifactId>
<version>3.15.1</version>
</dependency>
Run Code Online (Sandbox Code Playgroud)
但是,这在执行时会抛出 NoInitialContextException。堆栈跟踪:
Exception in thread "main" java.lang.RuntimeException: javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial
at org.sql2o.JndiDataSource.getJndiDatasource(JndiDataSource.java:27)
at org.sql2o.Sql2o.<init>(Sql2o.java:36)
at me.mypackage.sqlitetest.SqliteTest.main(SqliteTest.java:11)
Caused by: javax.naming.NoInitialContextException: Need to specify class name in environment or …Run Code Online (Sandbox Code Playgroud) 由于缺乏更好的词汇,我选择了这个头衔.
我想要的是能够做这样的事情:
>>> from random import randint
>>> fruits = [
... "Orange",
... "Banana",
... f"{randint(2,5)} Cherries",
... ]
>>> fruits[2]
'3 Cherries'
>>> fruits[2]
'5 Cherries'
>>> fruits[2]
'2 Cherries'
Run Code Online (Sandbox Code Playgroud)
但相反,字符串中的文字表达式在创建列表时会被评估一次,并在每次访问时得到相同的结果.
我想知道除了编写一些复杂的边缘案例处理之外是否还有一种更容易/更聪明的方法来解决这个问题(毕竟我们是程序员;谁不喜欢编写漂亮的代码并且优雅和喜欢?).我说的是边缘案例处理,因为我的49个字符串中只有6个需要这种"特殊"行为.
到目前为止我所尝试的是从randint调用中创建一个lambda函数,但这并没有帮助; 同样的结果.也许这是懒惰评估的一个案例,但我需要一些指导如何(或是否?)将它与列表一起使用.