调用有道词典查询单词

  1. package com.example.happydictionary;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.text.TextUtils;
  5. import android.view.Menu;
  6. import android.view.View;
  7. import android.widget.EditText;
  8. import android.widget.TextView;
  9. import com.example.happydictionary.dao.WordDao;
  10. public class MainActivity extends Activity {
  11. private WordDao wordDao;
  12. private EditText etWord;
  13. private TextView tvResult;
  14. @Override
  15. protected void onCreate(Bundle savedInstanceState) {
  16. super.onCreate(savedInstanceState);
  17. setContentView(R.layout.activity_main);
  18. initViews();
  19. }
  20. private void initViews() {
  21. etWord = (EditText) findViewById(R.id.etWord);
  22. tvResult = (TextView) findViewById(R.id.tvSearchResult);
  23. }
  24. @Override
  25. public boolean onCreateOptionsMenu(Menu menu) {
  26. // Inflate the menu; this adds items to the action bar if it is present.
  27. getMenuInflater().inflate(R.menu.main, menu);
  28. return true;
  29. }
  30. public void searchWord(View view) {
  31. String english = etWord.getText().toString();
  32. wordDao = new WordDao(this);
  33. if (TextUtils.isEmpty(english)) {
  34. tvResult.setText("请输入您想查询的单词");
  35. } else {
  36. String chinese = wordDao.getChinese(english);
  37. tvResult.setText(chinese);
  38. }
  39. }
  40. }

二   activity_main.xml

[java] view plaincopy

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:background="@drawable/mainbg"
  6. android:paddingBottom="@dimen/activity_vertical_margin"
  7. android:paddingLeft="@dimen/activity_horizontal_margin"
  8. android:paddingRight="@dimen/activity_horizontal_margin"
  9. android:paddingTop="@dimen/activity_vertical_margin"
  10. tools:context=".MainActivity" >
  11. <EditText
  12. android:id="@+id/etWord"
  13. android:layout_width="wrap_content"
  14. android:layout_height="wrap_content"
  15. android:layout_alignParentLeft="true"
  16. android:layout_alignParentTop="true"
  17. android:layout_marginTop="31dp"
  18. android:background="@android:drawable/edit_text"
  19. android:ems="10"
  20. android:hint="@string/searchHint"
  21. android:singleLine="true"
  22. android:textColor="#552006"
  23. android:textColorHint="#782f10" >
  24. <requestFocus />
  25. </EditText>
  26. <Button
  27. android:id="@+id/btnSearch"
  28. android:layout_width="wrap_content"
  29. android:layout_height="wrap_content"
  30. android:layout_alignBaseline="@+id/etWord"
  31. android:layout_alignBottom="@+id/etWord"
  32. android:layout_marginLeft="16dp"
  33. android:layout_toRightOf="@+id/etWord"
  34. android:background="@drawable/ibsearchword"
  35. android:onClick="searchWord"
  36. android:text="@string/serachWord" />
  37. <TextView
  38. android:id="@+id/tvSearchResult"
  39. android:layout_width="match_parent"
  40. android:layout_height="match_parent"
  41. android:layout_alignLeft="@+id/etWord"
  42. android:layout_below="@+id/etWord"
  43. android:layout_marginTop="22dp"
  44. android:textSize="25sp"
  45. android:background="@drawable/bg_roundcorner"
  46. android:textAppearance="?android:attr/textAppearanceMedium" />
  47. </RelativeLayout>

[java] view plaincopy

  1. 三 DBHelper 类

[java] view plaincopy

  1. package com.example.happydictionary.db;
  2. import java.io.File;
  3. import java.io.FileNotFoundException;
  4. import java.io.FileOutputStream;
  5. import java.io.IOException;
  6. import java.io.InputStream;
  7. import com.example.happydictionary.R;
  8. import com.example.happydictionary.R.raw;
  9. import android.content.Context;
  10. import android.database.sqlite.SQLiteDatabase;
  11. import android.os.Environment;
  12. import android.util.Log;
  13. /**
  14. * 实现将数据库文件从raw目录拷贝到手机里存放数据库的位置
  15. *
  16. * @author cabbage
  17. */
  18. public class DBHelper {
  19. private final int BUFFER_SIZE = 400000;
  20. public static final String DB_NAME = "idiom.db"; // 保存的数据库文件名
  21. public static final String PACKAGE_NAME = "com.example.happydictionary";// 应用的包名
  22. public static final String DB_PATH = "/data"
  23. + Environment.getDataDirectory().getAbsolutePath() + "/"
  24. + PACKAGE_NAME + "/databases";
  25. /*// SDCard 定义数据库的存放路径
  26. private final String DATABASE_PATH = android.os.Environment
  27. .getExternalStorageDirectory().getAbsolutePath() + "/dictionary";*/
  28. private Context context;
  29. public DBHelper(Context context) {
  30. this.context = context;
  31. }
  32. public SQLiteDatabase openDatabase() {
  33. try {
  34. File myDataPath = new File(DB_PATH);
  35. if (!myDataPath.exists()) {
  36. myDataPath.mkdirs();// 如果没有这个目录则创建
  37. }
  38. String dbfile = myDataPath + "/" + DB_NAME;
  39. if (!(new File(dbfile).exists())) {// 判断数据库文件是否存在,若不存在则执行导入,否则直接打开数据库
  40. InputStream is = context.getResources().openRawResource(
  41. R.raw.dictionary); // 欲导入的数据库
  42. FileOutputStream fos = new FileOutputStream(dbfile);
  43. byte[] buffer = new byte[BUFFER_SIZE];
  44. int count = 0;
  45. while ((count = is.read(buffer)) > 0) {
  46. fos.write(buffer, 0, count);
  47. }
  48. fos.close();
  49. is.close();
  50. }
  51. SQLiteDatabase db = SQLiteDatabase.openOrCreateDatabase(dbfile,
  52. null);
  53. return db;
  54. } catch (FileNotFoundException e) {
  55. Log.e("Database", "File not found");
  56. e.printStackTrace();
  57. } catch (IOException e) {
  58. Log.e("Database", "IO exception");
  59. e.printStackTrace();
  60. }
  61. return null;
  62. }
  63. }

时间: 2024-10-23 06:07:59

调用有道词典查询单词的相关文章

调用有道词典查词

调用有道词典 DbHelper类进行数据操作,activity_mian.xml布局页面,MainAvtivity类实现继承与查询等操作. MainAvtivity.java: 1 package com.example.happydictionary; 2 3 import android.app.Activity; 4 import android.os.Bundle; 5 import android.text.TextUtils; 6 import android.view.Menu;

android/java调用有道词典

之前学的时候碰了两壁:1.android4.0以上不能在主线程使用网络,2.不能在线程更新UI状态 因为网上很多给出的代码都有这两个隐患,所以很多人都调用不成功.明白了这两点下面就好办了. PS:代码非原创,由网络上android4.0以下的低版本代码改进而来,适用于android4.0以上,当然之前的应该也适用 直接上demo---translate http://pan.baidu.com/s/1gdIK4QR android/java调用有道词典

Android有道词典查询功能

有道词典 任务要求:完成查词等功能 因为需要申请API key,这里直接给出地址供使用:http://fanyi.youdao.com/openapi?path=data-mode 1.activity_main.xml基本格局(不做任何说明) 代码如下: 1 <RelativeLayout 2 xmlns:android="http://schemas.android.com/apk/res/android" 3 xmlns:tools="http://schemas

ubuntu下python脚本调用有道词典API实现命令行查词

#!/usr/bin/env python #coding=utf-8 '''   python使用有道词典的API来实现命令行查词 ''' import urllib2 import json import sys  reload(sys) sys.setdefaultencoding('utf-8') key = '1096888977' keyfrom = 'bloketest' doctype = 'json' u = 'http://fanyi.youdao.com/openapi.d

WebView调用有道词典实如今线查词

    WebView(网络视图)能载入显示网页,能够将其视为一个浏览器.它使用了WebKit渲染引擎载入显示网页,用法非常easy,直接在XML文件里写入webview控件就可以,主要代码例如以下: <AbsoluteLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_heigh

WebView调用有道词典实现在线查词

    WebView(网络视图)能加载显示网页,可以将其视为一个浏览器.它使用了WebKit渲染引擎加载显示网页,使用方法很简单,直接在XML文件中写入webview控件即可,主要代码如下: <AbsoluteLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height=&q

Python爬虫实践 —— 3.利用爬虫提取返回值,模拟有道词典接口

有道词典的web接口,实际上可以用爬虫模拟,输入key,拼接为有道词典接口的formdata,爬取返回值,实际为Ajax动态生成的translation,这样外部来看实现了翻译接口的模拟,相当于爬虫模拟浏览器调用了有道词典web接口,其实讲真的话来说,直接调用有道web接口,传json参数就可以了,不用这么费事,但爬虫模拟了人登陆web,输入关键词,获得翻译结果的过程. 浏览器输入操作,解析有道词典翻译的web接口url和格式 #爬虫模拟调用有道词典web接口调用 from urllib imp

Java和Python使用有道词典制作查单词脚本

Java和Python使用有道词典制作查单词脚本 先上两张图看一下效果 Java的: Python的: 今天突发奇想,想做个查单词的东西,就赶紧去有道词典官网看了一下,原来我们要查询的单词是嵌入在网页地址中送给有道词典的,然后页面的结果就是我们需要的单词释义,所以这个东西需要的技术知识只有: 正则表达式 我们要做的只是从获取到的网页源码中提取处单词释义,所以这里只说提取单词释义的正则表达式. 分析网页源码,我们可以看到,单词释义都在一个div标签内,如图: 首要目标是获取这一部分,正则表达式可以

调用网易有道词典api

# -*- coding: utf-8 -*- #python 27 #xiaodeng #调用网易有道词典api import urllib import json class Youdao(): def __init__(self,word): self.url='http://fanyi.youdao.com/openapi.do' #url.key.keyfrom都是固定的值,所以采用这种方式赋值 self.key='929705525' self.keyfrom='pythonxiao